题解 | #大数乘法#

大数乘法

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

最简单的做法:先不进位,把各个位的数算出来,同一位置累加,最后再做进位操作。

以6789 x 8976为例:

alt

class Solution {
public:
    void str2num(string& s, vector<int>& num){
        for(char c: s){
            num.push_back(c - '0');
        }
        reverse(num.begin(), num.end());
    }
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     * 
     * @param s string字符串 第一个整数
     * @param t string字符串 第二个整数
     * @return string字符串
     */
    string solve(string s, string t) {
        // write code here
        string ret;
        if(atoi(s.c_str()) == 0 or atoi(t.c_str()) == 0){
            return "0";
        }
        vector<int> s_num, t_num;
        str2num(s, s_num);
        str2num(t, t_num);
        int n1 = s.size();
        int n2 = t.size();
        vector<int> res(n1+n2);
        
        for(int i = 0; i < n1; i++){
            for(int j = 0; j < n2; j++){
                res[i + j] += s_num[i] * t_num[j];
            }
        }
        int carry = 0;
        for(int i = 0; i < res.size(); i++){
            res[i] = res[i] + carry;
            carry = res[i] / 10;
            res[i] = res[i] % 10;
        }
        if(res.back() == 0){
            res.erase(res.end()-1);
        }
        
        reverse(res.begin(), res.end());
        for(auto num: res){
            ret.append(to_string(num));
        }
        return ret;
    }
};
全部评论

相关推荐

10-28 11:04
已编辑
美团_后端实习生(实习员工)
一个2人:我说几个点吧,你的实习经历写的让人觉得毫无含金量,你没有挖掘你需求里的 亮点, 让人觉得你不仅打杂还摆烂。然后你的简历太长了🤣你这个实习经历看完,估计没几个人愿意接着看下去, sdk, 索引这种东西单拎出来说太顶真了兄弟,好好优化下简历吧
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务