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

 更新时间:2017年08月11日 08:54:50   作者:叶赫那拉坤  
这篇文章主要介绍了C++实现的大数相乘算法,结合实例形式分析了C++大数相乘的概念、原理及代码实现技巧,需要的朋友可以参考下

本文实例讲述了C++实现的大数相乘算法。分享给大家供大家参考,具体如下:

昨晚校招笔试,虐的没脸睡觉,能力太渣了,但我还在码农的坑里前行,希望早日跳坑,解决衣食住行之忧。

大数相乘,是指那些相乘结果或是乘数本身用long long类型都会溢出的数字,通常这些数字都通过string类型进行表示,借助于可动态调整大小的数据结构(vector,string,deque)模拟实现数字的乘法操作。对于普通的乘法,我们知道m位数和n位数相乘,最后的结果位数在区间内[m+n-1,m+n]。例如34*56,我们通常这么计算:

将3,4分别于6相乘,记录低位的进位,然后将3,4对5进行相同的操作,知道第二个乘数的最高位乘完,算法结束。

所以我们可以保存每个位数的相乘结果,最后统一进位转换。

#include<iostream>
#include<deque>
#include<sstream>
std::string BigNumMultiply(std::string s1,std::string s2){
 //记录最终结果
 std::string res="";
 //使用deque是因为出现进位时可以在队列前插入数据,效率比vector高,大小设为最小
 std::deque<int> vec(s1.size()+s2.size()-1,0);
 for(int i=0;i<s1.size();++i){
  for(int j=0;j<s2.size();++j){
   vec[i+j]+=(s1[i]-'0')*(s2[j]-'0');//记录相乘结果
  }
 }
 //进位处理
 int addflag=0;
 //倒序遍历,是因为最左边的值为最高位,最右边的值在最低位,进位运算要从低位开始
 for(int i=vec.size()-1;i>=0;--i){
  int temp=vec[i]+addflag;//当前值加上进位值
  vec[i]=temp%10;//当前值
  addflag=temp/10;//进位值
 }
 //如果有进位,将进位加到队列头部
 while(addflag!=0){
  int t=addflag%10;
  vec.push_front(t);
  addflag/=10;
 }
 for(auto c:vec){
  std::ostringstream ss;
  ss<<c;
  res=res+ss.str();
 }
 return res;
}
int main(){
 std::string str1,str2;
 while(std::cin>>str1>>str2)
 {
  std::cout<<str1<<"*"<<str2<<"="<<std::endl;
  std::cout<<BigNumMultiply(str1,str2)<<std::endl;
 }
 return 0;
}

希望本文所述对大家C++程序设计有所帮助。

相关文章

  • Cocos2d-x人物动作类实例

    Cocos2d-x人物动作类实例

    这篇文章主要介绍了Cocos2d-x人物动作类实例,本文用大量代码和图片讲解Cocos2d-x中的动作,代码中同时包含大量注释说明,需要的朋友可以参考下
    2014-09-09
  • C/C++的堆栈内存分配的实现

    C/C++的堆栈内存分配的实现

    内存管理是至关重要的一个方面,堆和栈是C语言中重要的内存分配方式,本文主要介绍了C/C++的堆栈内存分配的实现,详细的介绍了这两者在管理方式、性能和使用场景,感兴趣的可以了解一下
    2024-07-07
  • 浅谈Windows系统下C语言编程中Glib库的使用

    浅谈Windows系统下C语言编程中Glib库的使用

    这篇文章主要介绍了Windows系统下C语言编程中Glib库的使用,Glib库在多线程编程中经常可以用到,需要的朋友可以参考下
    2016-02-02
  • 怎么实现类的成员函数作为回调函数

    怎么实现类的成员函数作为回调函数

    不使用成员函数,为了访问类的成员变量,可以使用友元操作符(friend),在C++中将该函数说明为类的友元即可
    2013-10-10
  • 详解C语言之动态内存管理

    详解C语言之动态内存管理

    本文主要介绍了C语言动态内存管理的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • CMake编译中的库文件和头文件链接你了解吗

    CMake编译中的库文件和头文件链接你了解吗

    这篇文章主要为大家详细介绍了CMake编译中的库文件和头文件链接,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • C++布隆过滤器的使用示例

    C++布隆过滤器的使用示例

    宁可错杀一千,也不放过一个,这是布隆过滤器的特点,本文主要介绍了C++布隆过滤器的使用示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-09-09
  • C++实现词法分析器

    C++实现词法分析器

    这篇文章主要为大家详细介绍了C++实现词法分析器的相关代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • C++中std::stringstream多类型数据拼接和提取用法小结

    C++中std::stringstream多类型数据拼接和提取用法小结

    本文主要介绍了C++中std::stringstream多类型数据拼接和提取用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-09-09
  • 深入理解c++常成员函数和常对象

    深入理解c++常成员函数和常对象

    下面小编就为大家带来一篇深入理解c++常成员函数和常对象。小编觉得挺不错的,现在分享给大家,也给大家做个参考,一起跟随小编过来看看吧
    2016-05-05

最新评论