大整数加法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;
}
相关推荐
qq_3928079520 小时前
TCP/IP c/c++
网络·c++
qunaa010120 小时前
基于改进YOLO11-ASF-P2的多旋翼无人机检测识别系统_红外航拍目标检测算法优化_1
算法·目标检测·无人机
Xの哲學20 小时前
Linux 页回收机制深度剖析: 从设计哲学到实战调试
linux·服务器·网络·算法·边缘计算
柏木乃一20 小时前
基础IO(中)
linux·服务器·c++·io·进程·系统编程·缓冲区
幽络源小助理20 小时前
Yolo-Seg实例分割自动标注工具-幽络源原创
算法·yolo·实例分割·自动标注
天若有情67321 小时前
详解Two Pair函数:「一次握手,一次挥手」,让函数调用更严谨、更安全
网络·c++·后端·安全·设计
Howrun77721 小时前
虚幻引擎_UI搭建流程
c++·游戏引擎·虚幻
橘颂TA21 小时前
【剑斩OFFER】算法的暴力美学——LeetCode 703 题:数据流中的第 K 大元素
网络·算法·结构与算法
信奥卷王21 小时前
2025年9月GESPC++四级真题解析(含视频)
数据结构·c++·算法
朔北之忘 Clancy21 小时前
第一章 顺序结构程序设计(2)
c++·算法·青少年编程·竞赛·教材·考级·讲义