大数乘法

题目描述

image.png

题解

预先分配好字符串的长度,在每一位计算对应结果,乘法和加法同时进行
这里还要利用几个规律:

  • 长度为m和n的两个数相乘,结果的长度不会超过m+n,所以先定义一个m+n的字符串用来存放结果
  • 然后第i位(0<=i<=m-1)和第j位(0<=j<=n-1)的乘积对应结果的第i+j+1位,进位要进到第i+j位

注意点:

  • 最后要检查结果的高位是否有多余的'0',要排除结果本身就是'0'的特殊情况。

string的常用方法:

  • 构造
string s(n, c)

上式定义了一个长度为n的字符串,字符串中每个元素均为字符c

  • 求长度
s.size()
  • 从某个位置删除一个或多个字符
s.erase(int pos, int n)

其中pos为要删除第一个字符的位置,n为删除的长度

代码

// solve.cpp
#include <iostream>
#include <string>

using namespace std;

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * @param s string字符串 第一个整数
     * @param t string字符串 第二个整数
     * @return string字符串
     */
    string solve(string s, string t) {
        // write code here
        int temp;
        string result(s.size() + t.size(), '0');
        for (int i = s.size() - 1; i >=0; i--){
            for (int j = t.size() - 1; j >=0; j--){
                temp = (s[i] - '0') * (t[j] - '0') + (result[i + j + 1] - '0');
                result[i + j + 1] = temp % 10 + '0';
                result[i + j] += temp / 10;
            }
        }
        int i = 0;
        while (result[i] == '0' && i < result.size() - 1){
            i++;
        }
        result.erase(0, i);
        return result;
    }
};

int main(){
    string a = "11";
    string b = "99";
    Solution s;
    cout << s.solve(a, b) << endl;
    return 0;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 大数乘法的算法 大数乘法的关键在于如何用字符串来模拟大数乘法。方法有如下几种:模拟普通的手算乘法、利用代数方法优化...
    胡哈哈哈阅读 6,036评论 0 0
  •   作为相继出现在ACM、华为腾讯等大厂的面试、笔试中的一道算法题,大数乘法还是挺需要深入研究一下的。因此,今天就...
    楠子小先生阅读 5,096评论 2 1
  • 1、大数乘法 (1)转换并反转,字符串转换为数字并将字序反转; (2)自动移位,逐位相乘,添加最后的进位; (3)...
    saviochen阅读 3,526评论 0 2
  • 其实大数乘法就是在考虑大数加法的进位的同时,考虑字符串num1和字符串num2相乘时,每一位所在的位置,以及加法运...
    小太阳花儿阅读 1,781评论 0 2
  • 近日参加一个笔试,遇到大数乘法问题,这是一个经典的算法题。所谓大数乘法问题其实就是这样的:输入两个整数,要求输出这...
    拉普拉斯妖kk阅读 8,253评论 0 2