基础算法—高精度算法


前言

为什么要用高精度算法?

  1. 在C/C++中,我们经常会碰到限定数据范围的情况,我们先来看常用的int和long long两种数据类型的范围吧。

  2. int占32位,即4个字节,所以int的范围是[ − 2 31 -2^{31} 231 , 2 31 − 1 2^{31}-1 2311],为 1 0 9 10^9 109数量级

  3. long long占64位,即8个字节,所以long long的范围是[ − 2 63 -2^{63} 263 , 2 63 − 1 2^{63}-1 2631],为 1 0 18 10^{18} 1018数量级。

  4. 如果超过该数量级,该怎么办?那就需要用到高精度算法。

2 31 2^{31} 231 = 2147483648 (10位数)
2 63 2^{63} 263 = 9223372036854775808 (19位数)

1、高精度加法

1.1问题描述
在这里插入图片描述

1.2:竖式加法
在这里插入图片描述
1.3算法核心
在这里插入图片描述
1.4代码示例

#include<iostream>
#include<cstdio> //c语言头文件 
#include<cstring> //strlen()的头文件
#include<cstdlib> //max()的头文件 

using namespace std;

char s1[505], s2[505];
int a[505], b[505], c[505];

int main(){
	//定义在main()里面的数组会有问题 
//	char s1[505], s2[505];
//	int a[505], b[505], c[505];

	int La, Lb, Lc;
	
	scanf("%s", s1);
	scanf("%s", s2);
	
	La = strlen(s1); //La = 4 
	Lb = strlen(s2); //Lb = 3 
	
	//检查 
//	cout << La << ' ' << Lb;
	
	for(int i = 0; i < La; i++){
		a[La - i] = s1[i] - '0';
	}
	 
	
	for(int i = 0; i < Lb; i++){
		b[Lb - i] = s2[i] - '0';

	}
	
	Lc = max(La, Lb) + 1; //Lc = 5 
	
	for(int i = 1; i <= Lc; i++){
		c[i] += a[i] + b[i]; 
		c[i+1] = c[i]/10; //进位 
		c[i] = c[i]%10;
	}
	
	if(c[Lc] == 0 && Lc > 0){ //解决特例:去除前面的0 
		Lc--;

	}
	
	for(int i = Lc; i > 0; i--){
		printf("%d", c[i]);

	}
	
	return 0; 
} 
  • 前导0的处理
    在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值