LeetCode43字符串相乘

目录

题目描述

思路:

普通竖式

优化竖式

优化代码


题目描述

 

思路:

一开始我想要使用atoi()和to_string()两个函数(分别来自cstdlib和sstream库),但是最后的结果超过了 long的限制.所以我就没法了,想着,硬着头皮模拟一遍好了.

普通竖式

 思路比较简单,我们写两个函数.一个函数负责返回两个string相加的结果,另一个函数负责模拟每一行相乘的结果.先算出相乘的结果,再拿结果和之前算出的res进行字符串相加函数操作.中间有一些细节问题要注意:

1)每一次保存一行数据的ans字符串,这个字符串每一次要在头部加上有规律个数的字符'0'来模拟手动乘法中的移位计算.

2)我们在进行add(res,ans)之前.需要先将ans字符串进行reverse操作!


class Solution {
public:
    string multiply(string num1, string num2) {
        if (num1[0] == '0' || num2[0] == '0')  return "0";
        int i = num2.size() - 1;
        int sub = num2.size() - 1;
        int j = num1.size() - 1;
        int temp_i;
        int temp_j;
        int mul = 0;
        string ans = "";
        string res = "";
        for (; i >= 0; --i) {
            temp_i = i;
            temp_j = j;
            ans.clear();
            while (sub - temp_i > 0) {
                ans.push_back('0');
                temp_i++;
            }
            /*num1*num2
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Shallow_Carl

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值