C++大数加法——最简单实现

高精度加法

题目描述

给定两个整数 和 ,请你求出这两个整数的和。

输入描述

输入两个正整数 a,b, a和b都不超过100位。

输出描述

输出两数之和

输入样例

复制代码
1
2

输出样例

复制代码
3

输入样例

复制代码
1234567890123456789
9876543210987654321

输出样例

复制代码
11111111101111111110

思路及代码

cpp 复制代码
#include<iostream>
#include<vector>
#include<algorithm>
//#define DEBUG true
using namespace std; 
const int maxLine = 100+10;
void initRedict(){
	#ifdef DEBUG
	cout<<"执行重定向"; 
	freopen("../redict/demo/demo_in.txt","r",stdin);
	#endif
} 
string a,b;
vector<int> revVecA,revVecB;
int sumNums[maxLine];
int main(){
	initRedict(); 
	cin>>a>>b;
	// 逆序读取 录入容器 
	for(int i=a.size()-1;i>=0;i--)  revVecA.push_back(a[i]-'0');
	for(int i=b.size()-1;i>=0;i--)  revVecB.push_back(b[i]-'0');
	// 获取a,b字符串长短 (如果有负数就需要使用其他方法判断了)
	// 这里适用于正大数加法 
	int maxlen=max(a.size(),b.size());
	int minlen=min(a.size(),b.size());
	// 计算主体	
	int jinwei=0;
	for(int i=0;i<maxlen;i++){
		int addNums;
		if (i<minlen) addNums=revVecA[i]+revVecB[i];
		else if (a.size()>=b.size()) addNums=revVecA[i];
		else addNums=revVecB[i];
		
		sumNums[i]+=(addNums+jinwei)%10;
		jinwei=(addNums+jinwei)/10;
	}
	// 末尾特判 
	sumNums[maxlen]=jinwei;
	if (jinwei) maxlen++;
	//输出res 
	for(int i=maxlen-1;i>=0;i--){
		cout<<sumNums[i]; 
	}
	return 0;
}
相关推荐
2301_80421541几秒前
模板元编程应用场景
开发语言·c++·算法
实心儿儿4 分钟前
C++ —— 红黑树
java·开发语言·算法
炘爚7 分钟前
C++(普通指针和成员的区别、指针的使用场景和存储内容)
数据结构·c++·算法
松☆7 分钟前
C++ 控制台通讯录管理系统 —— 从零实现到完整解析(附可运行代码)
开发语言·网络·c++
Book思议-8 分钟前
【数据结构考研真题】栈和队列(小题)
数据结构·考研·栈和队列·408小题
炘爚9 分钟前
C++(在Mystring类中碰到的构造函数和析构函数以及深拷贝和浅拷贝的问题)
开发语言·c++·算法
hz_zhangrl11 分钟前
CCF-GESP 等级考试 2026年3月认证C++四级真题解析
c++·程序设计·gesp·c++四级·gesp2026年3月·gesp c++四级
Fang fan22 分钟前
Java集合
java·开发语言·算法
AI成长日志26 分钟前
【笔面试算法学习专栏】链表操作专题:反转、环形检测与合并
学习·算法·面试
liulilittle27 分钟前
TC Hairpin NAT 驱动使用手册(个人版)
服务器·开发语言·网络·c++·网络协议·tcp/ip·tc