[C++] 高精度加法(作用 + 模板 + 例题)

高精度加法-目录

高精度加法用途

高精度加法通常用于加很大的数(真的很大, 超unsigned long long的那种).

高精度加法模板

注: 本篇数组下标0(x[0])存储的是该数组的有效位数.

string转数位数组

我们一般使用string类型存储很大的数.

这个时候, 高精度加法要干的是模拟列竖式, 把每一位加起来, 然后再考虑进位的问题 . 模拟列竖式需要数位末尾对齐 , 所以我们最好把原始数据反转一下.

考虑以上两点, 需要先把string转换成int数位数组. 在这里我们以普通int数组举例, 除此之外还能用vector或者short数组或者继续用string也行.

cpp 复制代码
// 头文件
#include <iostream>
#include <string>
using namespace std;

// **** 重点!!! ****
// 一般我们用'2'表示英语单词'to'
void s2BIG(string s, int a[]){
	int len = s.size();
	for(int i = 1; i <= len; i++){
		a[i] = s[len - i] - '0';
	}
	a[0] = len;
}

// 使用方法
int main(){
	string s;
	cin >> s;
	s2BIG(s, A);
	// ......
	return 0;
}

int 转数位数组(附加型知识点)

这是一个特殊的点, 因为有时候我们要把int和所谓的BIG进行高精度运算, 这时我们需要把int转换为BIG(数位数组) .通过while拆位实现.

cpp 复制代码
void i2BIG(int n, int a[]){
	int cur = 0;
	while(n > 0){
		cur++;
		a[cur] = n % 10;
		n /= 10;
	}
	if(cur == 0) cur++;
	a[0] = cur;
}

后续代码会把这段加上, 但可能不会再用.


高精度输出

我们先把辅助的代码讲完. 我们完成加法后, 我们肯定要把它输出出来, 由于是反着计算的, 所以要反着输出. 这个时候我们就需要高精度输出. 我们实现的功能是把进入函数的数组反向输出 .

本段代码整合了上一段的代码.

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;

int a[1005];

void s2BIG(string s, int a[]){
	int len = s.size();
	for(int i = 1; i <= len; i++){
		a[i] = s[len - i] - '0';
	}
	a[0] = len;
}

void i2BIG(int n, int a[]){
	int cur = 0;
	while(n > 0){
		cur++;
		a[cur] = n % 10;
		n /= 10;
	}
	if(cur == 0) cur++;
	a[0] = cur;
}

void printBIG(int a[]){
	int len = a[0];
	for(int i = len; i > 0; i--){
		cout << a[i];
	}
	cout << endl;
}

int main(){
	string s;
	cin >> s;
	s2BIG(s, a);
	printBIG(a);
	return 0;
}

高精度加法

分为以下部分:

  • 写入有效长度
  • 对应位数求和
  • 处理进位情况
  • 根据最高位更新长度
cpp 复制代码
#include <iostream>
#include <algorithm>
#include <string>
using namespace std;

int x[1005], y[1005], z[1005];

void s2BIG(string s, int a[]){
	int len = s.size();
	for(int i = 1; i <= len; i++){
		a[i] = s[len - i] - '0';
	}
	a[0] = len;
}

void i2BIG(int n, int a[]){
	int cur = 0;
	while(n > 0){
		cur++;
		a[cur] = n % 10;
		n /= 10;
	}
	if(cur == 0) cur++;
	a[0] = cur;
}

void printBIG(int a[]){
	int len = a[0];
	for(int i = len; i > 0; i--){
		cout << a[i];
	}
	cout << endl;
}

/**** 新增 ****/
void addBIG(int x[], int y[], int z[]){
	z[0] = max(x[0], y[0]);				// 先写出有效长度
	for(int i = 1; i <= z[0]; i++)		// 对应位求和
		z[i] = x[i] + y[i];
	for(int i = 1; i <= z[0]; i++){		// 处理进位
		z[i + 1] += z[i] / 10;
		z[i] %= 10;
		if(z[z[0] + 1] != 0)			// 处理最高位进位, 更新有效位数
			z[0]++;
	}
}

int main(){
	string a, b;
	cin >> a >> b;
	s2BIG(a, x);
	s2BIG(b, y);
	addBIG(x, y, z);
	printBIG(z);
	return 0;
}

函数大合集!!!

cpp 复制代码
void s2BIG(string s, int a[]){
	int len = s.size();
	for(int i = 1; i <= len; i++){
		a[i] = s[len - i] - '0';
	}
	a[0] = len;
}

void i2BIG(int n, int a[]){
	int cur = 0;
	while(n > 0){
		cur++;
		a[cur] = n % 10;
		n /= 10;
	}
	if(cur == 0) cur++;
	a[0] = cur;
}

void printBIG(int a[]){
	int len = a[0];
	for(int i = len; i > 0; i--){
		cout << a[i];
	}
	cout << endl;
}

void addBIG(int x[], int y[], int z[]){
	z[0] = max(x[0], y[0]);				// 先写出有效长度
	for(int i = 1; i <= z[0]; i++)		// 对应位求和
		z[i] = x[i] + y[i];
	for(int i = 1; i <= z[0]; i++){		// 处理进位
		z[i + 1] += z[i] / 10;
		z[i] %= 10;
		if(z[z[0] + 1] != 0)			// 处理最高位进位, 更新有效位数
			z[0]++;
	}
}
相关推荐
千禧皓月3 分钟前
【C++】基于C++的RPC分布式网络通信框架(二)
c++·分布式·rpc
zl_vslam6 分钟前
SLAM中的非线性优-3D图优化之轴角在Opencv-PNP中的应用(一)
前端·人工智能·算法·计算机视觉·slam se2 非线性优化
是苏浙20 分钟前
零基础入门C语言之C语言实现数据结构之顺序表应用
c语言·数据结构·算法
南汐汐月23 分钟前
重生归来,我要成功 Python 高手--day33 决策树
开发语言·python·决策树
AA陈超29 分钟前
虚幻引擎5 GAS开发俯视角RPG游戏 P07-08 点击移动
c++·游戏·ue5·游戏引擎·虚幻
星释36 分钟前
Rust 练习册 :Proverb与字符串处理
开发语言·后端·rust
lkbhua莱克瓦241 小时前
Java基础——常用算法3
java·数据结构·笔记·算法·github·排序算法·学习方法
小白程序员成长日记1 小时前
2025.11.07 力扣每日一题
数据结构·算法·leetcode
·白小白1 小时前
力扣(LeetCode) ——209. 长度最小的子数组(C++)
c++·算法·leetcode
工会主席-阿冰1 小时前
数据索引是无序时,直接用这个数据去画图的话,显示的图是错误的
开发语言·python·数据挖掘