大整数加法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;
}
相关推荐
I Promise342 小时前
C++ 单例模式超详细讲解
开发语言·c++·单例模式
wuweijianlove2 小时前
算法性能优化中的数据流重构与依赖消解的技术6
算法
Agent手记2 小时前
智能财务对账Agent如何设计?2026金融大模型Agent架构设计与实战指引
人工智能·算法·ai·金融
Emerson_20262 小时前
stack,queue,list的区别和联系
数据结构·c++·list·queue·stack
计算机安禾2 小时前
【算法分析与设计】第5篇:最大子数组问题:分治与线性扫描的对比分析
算法
王老师青少年编程2 小时前
2026年全国青少年信息素养大赛初赛真题(算法应用主题赛C++初中组初赛真题2:文末附答案和解析)
c++·真题·答案·初赛·2026年·初中组·青少年信息素养大
z200509302 小时前
今日算法(组合问题)(回溯解法)
算法·深度优先
Shiy_2 小时前
用 TypeScript 验证三门问题:为什么换门胜率是 2/3?
算法·typescript
Yunzenn2 小时前
深度解析字节最新研究-Cola DLM 第 06 章:分块因果 DiT 先验 —— 在隐空间里做 Flow Matching
人工智能·算法·架构
HjhIron2 小时前
数组去重:从零开始,写一个靠谱的工具函数
算法·面试