题解 | #大数乘法#

大数乘法

https://www.nowcoder.com/practice/c4c488d4d40d4c4e9824c3650f7d5571

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param s string字符串 第一个整数
     * @param t string字符串 第二个整数
     * @return string字符串
     */
  //解法:无进位相乘,后相加
   public String solve (String ss, String tt) {
        char[] s = new StringBuffer(ss).reverse().toString().toCharArray();
        char[] t = new StringBuffer(tt).reverse().toString().toCharArray();
        int m = s.length,n = t.length;
        //无进位相乘
        int[] tmp = new int[m + n];
        for(int i = 0;i < m;i++){
            for(int j = 0;j < n;j++){
                //下标位置==两个数字的下标位置之和,累加
                tmp[i + j] += (s[i] - '0') * (t[j] - '0');
            }
        }
        //计算加法
        int c = 0;
        StringBuffer res = new StringBuffer();
        for(int x : tmp){
            c += x;
            res.append((char)(c % 10 + '0'));
            c /= 10;
        }
        //处理c不等于0的情况
        while(c != 0){
            res.append((char)(c % 10 + '0'));
            c /= 10;
        }
        //处理前导零
        while(res.length() > 1 && res.charAt(res.length() - 1) == '0'){
            res.deleteCharAt(res.length() - 1);
        }
        return res.reverse().toString();
    }
}

全部评论

相关推荐

头像
11-27 14:28
长沙理工大学
刷算法真的是提升代码能力最快的方法吗?&nbsp;刷算法真的是提升代码能力最快的方法吗?
牛牛不会牛泪:看你想提升什么,代码能力太宽泛了,是想提升算法能力还是工程能力? 工程能力做项目找实习,算法也分数据结构算法题和深度学习之类算法
点赞 评论 收藏
分享
牛舌:如果我不想去,不管对方给了多少,我一般都会说你们给得太低了。这样他们就会给下一个offer的人更高的薪资了。
点赞 评论 收藏
分享
11-09 17:30
门头沟学院 Java
TYUT太摆金星:我也是,好几个华为的社招找我了
点赞 评论 收藏
分享
评论
1
收藏
分享
牛客网
牛客企业服务