大整数加法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;
}
相关推荐
Brilliantwxx5 分钟前
【C++】认识vector(概念+题目OJ)
开发语言·c++·笔记·算法
上弦月-编程16 分钟前
C语言链表详解,新手也能看懂! ——从入门到精通的完整教程
java·c语言·c++
生成论实验室26 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第十篇:识势应势——从认知到行动的完整闭环
人工智能·算法·架构·创业创新·安全架构
risc12345628 分钟前
SegmentTermsEnum#postings 和 IntersectTermsEnum#postings
算法·lucene
阿Y加油吧30 分钟前
二刷 LeetCode:两道经典贪心题复盘
算法·leetcode·职场和发展
顺顺 尼31 分钟前
程序地址空间和进程的一些操作
算法
Java成神之路-33 分钟前
【LeetCode 刷题笔记】35. 搜索插入位置 | 二分查找经典入门题
算法·leetcode
CSCN新手听安35 分钟前
【Qt】Qt窗口(五)QDialog对话框的使用,点击按钮弹出新的对话框,自定义对话框界面,模态对话框model
开发语言·c++·qt
晴夏。38 分钟前
c++调用lua的方法
c++·游戏引擎·lua·ue
Lhan.zzZ8 小时前
笔记_2026.4.28_004
c++·ide·笔记·qt