leetcode43. 字符串相乘

传送门

题目: 给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。num1 和 num2 只包含数字 0-9。num1 和 num2 均不以零开头,除非是数字 0 本身。
输入: num1 = “2”, num2 = “3” 输出: “6”

在这里插入图片描述

num1的每一位和num2的每一位分别相乘 每一次得到一个两位数  
如3*5=151*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();
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值