大整数加法C++

大整数加法C++

方法

  • 小的数在前,大数在后
  • 加数、被加数进行翻转,从低位开始加起,因为数组是从0位开始,与正常手工加法不同。
  • 设置进位符carry_flag
  • 先对小的数进行控制,做加法
  • 再对大的数剩下的部分,做加法

代码

cpp 复制代码
#include<iostream> 
#include<cstring> 
using namespace std;
int add(char* s1,char* s2,char* buf){
	//确只s1比s2大 
	if(strlen(s1)>strlen(s2)) 
		return add(s2,s1,buf);
	//进位标志 
	int carry_flag=0;
	char* p=s1;
	char* q=s2;
	char* r=buf;
	while(*p){
		int t=(*p-'0')+(*q-'0')+carry_flag;
		*r=t%10+'0';
		carry_flag=t/10;
		++p;
		++q;
		++r;
	}
	while(*q){
		int t=*q-'0'+carry_flag;
		*r=t%10+'0';
		carry_flag=t/10;
		++q;
		++r;
	}
	if(carry_flag){
		*r='1';
		++r;
	}
	*r='\0';
	return 0;
}
int main(){
	char buf[200];
	char s1[] = "9999999999999999999999999999999";
	char s2[] ="123";
	cout<<"加数1:"<<s1<<endl;
	cout<<"加数2:"<<s2<<endl;
	strrev(s1);
	strrev(s2);
	add(s1,s2,buf);
	strrev(buf);
	cout<<"结果:" << buf <<endl;
	return 0;
}
相关推荐
Thera77710 分钟前
【Linux C++】彻底解决僵尸进程:waitpid(WNOHANG) 与 SA_NOCLDWAIT
linux·服务器·c++
Wei&Yan14 分钟前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
wregjru30 分钟前
【QT】4.QWidget控件(2)
c++
浅念-35 分钟前
C++入门(2)
开发语言·c++·经验分享·笔记·学习
小羊不会打字42 分钟前
CANN 生态中的跨框架兼容桥梁:`onnx-adapter` 项目实现无缝模型迁移
c++·深度学习
团子的二进制世界1 小时前
G1垃圾收集器是如何工作的?
java·jvm·算法
Max_uuc1 小时前
【C++ 硬核】打破嵌入式 STL 禁忌:利用 std::pmr 在“栈”上运行 std::vector
开发语言·jvm·c++
吃杠碰小鸡1 小时前
高中数学-数列-导数证明
前端·数学·算法
故事不长丨1 小时前
C#线程同步:lock、Monitor、Mutex原理+用法+实战全解析
开发语言·算法·c#
long3161 小时前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法