实现两个字符串的乘法
来源:互联网 发布:6直播wap源码 编辑:程序博客网 时间:2024/06/06 08:46
实现两个由数字构成的字符串的乘法,其实现代码如下所示:
#include<iostream>#include<string>#include<vector>using namespace std;string multiply(string &num1, string &num2){if (num1 == "0" || num2 == "0"){return "0";}int len1 = num1.length();int len2 = num2.length();vector<int> result(len1 + len2 - 1, 0);string resultStr = "";for (int i = len1 - 1; i >= 0; --i){for (int j = len2 - 1; j >= 0; --j){result[i + j] += (num1[i] - '0')*(num2[j] - '0');//关键的一步,两个位数和相等的乘积放在同一个地方}}string temp1, temp2;int k = len1 + len2 - 2;while (k != 0){temp1 = result[k] % 10 + '0';resultStr = temp1 + resultStr;result[k - 1] += result[k] / 10;--k;}temp1 = result[0] % 10 + '0';resultStr = temp1 + resultStr;if (result[0] >= 10){temp2 = result[0] / 10 + '0';resultStr = temp2 + resultStr;}return resultStr;}int main(){string s1 = "9";string s2 = "9";string s3 = "12564875421475";string s4 = "4578124754157841541";cout << "s1*s2 = " << multiply(s1, s2) << endl;cout << "s3*s4 = " << multiply(s3, s4) << endl;system("pause");return 0;}
实验结果如下所示:
0 0
- 实现两个字符串的乘法
- Multiply Strings 两个字符串的乘法
- 实现两个N*N矩阵的乘法
- 一个简单实现的字符串数字乘法。
- 两个数的乘法
- c实现的求两个数的乘法逆元
- 大数乘法。给定两个数字表示为字符串,返回乘数的数字作为一个字符串。
- javascript 字符串的乘法
- 字符串实现加法和乘法
- 两个大整数的乘法
- Swift中实现ruby中字符串乘法倍增的功能
- string实现两个字符串的连接
- Java实现两个字符串的比较
- java实现两个字符串的比较
- java实现两个字符串的比较
- Java实现两个字符串的比较
- 数组实现两个字符串的连接
- 用加法实现两个整数乘法操作
- git的学习(工作区与暂存区)
- Hive vs. HBase
- 去掉TableView中多余的分割线
- epoll-4
- LoadRunner分析资源占用率
- 实现两个字符串的乘法
- classPath 三个文章连接
- 你确实应该学习并使用的 10 个 C# 特性
- javaw.exe是什么?两个class文件可以同事运行
- 使用补偿算法对陀螺仪和电子罗盘进行数据融合,计算方位角
- Ubuntu16.04下 Matlab2015b安装与激活及注意事项:
- 单例
- 通过IL分析C#中的委托、事件、Func、Action、Predicate之间的区别与联系
- Highcharts 相关属性