栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

C++实现大数相乘的算法

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C++实现大数相乘的算法

由于数字无法用一个整形变量存储,很自然的想到用字符串来表示一串数字。然后按照乘法的运算规则,用一个乘数的每一位乘以另一个乘数,然后将所有中间结果按正确位置相加得到最终结果。可以分析得出如果乘数为A和B,A的位数为m,B的位数为n,则乘积结果为m+n-1位(最高位无进位)或m+n位(最高位有进位)。因此可以分配一个m+n的辅存来存储最终结果。为了节约空间,所有的中间结果直接在m+n的辅存上进行累加。

C++实现大数相乘代码如下:

#include   
#include
using namespace std;
 
 string BigNumMultiply(string str1,string str2)
 {
 int size1=str1.size(),size2=str2.size();
 string str(size1+size2,'0');
 for(int i=size2-1;i>=0;--i)
 {
 int mulflag=0,addflag=0;
 for(int j=size1-1;j>=0;--j)
 {
 int temp1=(str2[i]-'0')*(str1[j]-'0')+mulflag;
 mulflag=temp1/10;
 temp1=temp1%10;
 int temp2=str[i+j+1]-'0'+temp1+addflag;
 str[i+j+1]=temp2%10+48;
 addflag=temp2/10;
 }
 str[i]+=mulflag+addflag;
 }
 if(str[0]=='0')
 str=str.substr(1,str.size());
 return str;
 }
 
 int main()
 {
 string str1,str2;
 while(cin>>str1>>str2)
 {
 cout<

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/62325.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号