leetcode日记(32)字符串相乘

做了很久很久......真的太繁琐了!!

cpp 复制代码
class Solution {
public:
    string multiply(string num1, string num2) {
        string s;
        string str;
        if (num1 == "0" || num2 == "0") return "0";
        for(int i=num2.size()-1;i>=0;i--){
            int c2=num2[i]-'0';
            string x;
            int b=0;
            for(int j=num1.size()-1;j>=0;j--){
                int c1=num1[j]-'0';
                int c3=c1*c2;
                if(b>=1) c3+=b;
                if(c3>9){
                    x.insert(x.begin(),c3%10+'0');
                    b=c3/10;
                }
                else{x.insert(x.begin(),c3+'0');b=0;}
                if(b>=1&&j==0&&c3>9){
                    char u=c3/10+'0';
                    x.insert(x.begin(),u);
                }
            }
            if(s=="") s=x;
            else{
                int u=num2.size()-i-1;
                while(u>0) {x.push_back('0');u--;}
                s=ad(s,x);
            }
        }
        return s;
    }
    string ad(string a,string b){
        if(a.size()>=b.size()){
            for(int i=1;i<=a.size();i++){
                if(i<b.size()+1){
                    a[a.size()-i]+=b[b.size()-i]-'0';
                    if(a[a.size()-i]>'9'){
                        a[a.size()-i]-=10;
                        if(a.size()-i==0){
                            a.insert(a.begin(),'1');
                        }
                        else a[a.size()-i-1]+=1;
                    }
                }
                else{
                    if(a[a.size()-i]>'9'){
                        a[a.size()-i]-=10;
                        if(a.size()-i==0){
                            a.insert(a.begin(),'1');
                        }
                        else a[a.size()-i-1]+=1;
                    }
                }
            }
            return a;
        }
        else{
            for(int i=1;i<=b.size();i++){
                if(i<a.size()+1){
                    b[b.size()-i]+=a[a.size()-i]-'0';
                    if(b[b.size()-i]>'9'){
                        b[b.size()-i]-=10;
                        if(b.size()-i==0){
                            b.insert(b.begin(),'1');
                        }
                        else b[b.size()-i-1]+=1;
                    }
                }
                else{
                    if(b[b.size()-i]>'9'){
                        b[b.size()-i]-=10;
                        if(b.size()-i==0){
                            b.insert(b.begin(),'1');
                        }
                        else b[b.size()-i-1]+=1;
                    }
                }
            }
            return b;
        }
        return b;
    }
};
相关推荐
weixin_4461224611 分钟前
LinkedList剖析
算法
百年孤独_1 小时前
LeetCode 算法题解:链表与二叉树相关问题 打打卡
算法·leetcode·链表
我爱C编程2 小时前
基于拓扑结构检测的LDPC稀疏校验矩阵高阶环检测算法matlab仿真
算法·matlab·矩阵·ldpc·环检测
算法_小学生2 小时前
LeetCode 75. 颜色分类(荷兰国旗问题)
算法·leetcode·职场和发展
运器1232 小时前
【一起来学AI大模型】算法核心:数组/哈希表/树/排序/动态规划(LeetCode精练)
开发语言·人工智能·python·算法·ai·散列表·ai编程
算法_小学生2 小时前
LeetCode 287. 寻找重复数(不修改数组 + O(1) 空间)
数据结构·算法·leetcode
岁忧2 小时前
(LeetCode 每日一题) 1865. 找出和为指定值的下标对 (哈希表)
java·c++·算法·leetcode·go·散列表
alphaTao2 小时前
LeetCode 每日一题 2025/6/30-2025/7/6
算法·leetcode·职场和发展
ゞ 正在缓冲99%…2 小时前
leetcode67.二进制求和
算法·leetcode·位运算
YuTaoShao2 小时前
【LeetCode 热题 100】240. 搜索二维矩阵 II——排除法
java·算法·leetcode