题目: 给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。num1 和 num2 只包含数字 0-9。num1 和 num2 均不以零开头,除非是数字 0 本身。
输入: num1 = “2”, num2 = “3” 输出: “6”
num1的每一位和num2的每一位分别相乘 每一次得到一个两位数
如3*5=15 , 1*5=05
这样就能把每一次乘出来的两位找到数组对应的索引:
nums[i]*nums[j] 得到一个进位 一个末位
进位映射的地址是index[i+j] 末位映射地址是index[i+j+1]
(索引从右到左,index长度是len1+len2 )
注意 算 得到的两位数的时候 要加上index[i+j+1]:
sum = nums[i]*nums[j] + index[i+j+1]因为可能有持续进位
另外 存回index的时候 注意:
高位是累加的 index[i+j] += sum/10
但是末位是赋值 index[i+j+1] = sum%10 因为在上面加过了
public String multiply(String num1, String num2) {
int len1 = num1.length(), len2 = num2.length();
if (len1 == 0 || len2 == 0) return "";
if (num1.equals("0") || num2.equals("0")) return "0";
int[] index = new int[len1 + len2];
// 计算i, j 位相乘得到的结果,存入对应index
for (int i = len1 - 1; i >= 0; --i) { // 倒序,低位到高位
for (int j = len2 - 1; j >= 0; --j) {
int sum = (num1.charAt(i) - '0') *
(num2.charAt(j) - '0') +
index[i+j+1];
index[i + j] += sum / 10;
index[i + j + 1] = sum % 10;
}
}
StringBuilder sbAns = new StringBuilder();
int i = (index[0] == 0) ? 1 : 0; // index前面最多有一个前导0
while (i < index.length) sbAns.append(index[i++]);
return sbAns.toString();
}