高精度问题

news2024/12/27 14:26:20

目录

算法实现基础 

高精度加法A+B

测试链接 

源代码 

代码重点

高精度减法A-B

测试链接 

源代码 

代码重点

高精度乘法A*b和A*B

测试链接 

源代码 

代码重点

高精度除法A/b和A/B

测试链接 

源代码 

代码重点

高精度求和差积商余


算法实现基础 

本算法调用STL库函数vector容器来使用

vector库的详细用法可查看单链双链表以及vector 中的部分内容

建议学习过vector的使用方法之后再来看本算法文章

由于Java与Python等语言拥有特性可以不使用高精度算法实现

因此本篇文章主要讲解的是c++的高精度算法

高精度加法A+B

测试链接 

洛谷P1601 A+B Problem(高精)

源代码 

c++解法

代码重点

1.数字的存储为倒叙存储。就vector容器的特点来说,在头部插入元素的难度以及数据处理量要远远大于在尾部插入元素,因此对于长整数的存储来说,在vector容器当中倒叙存储(注意字符数组与字符数组的转换),对于答案容器中的数字也是倒叙存储。

2.t的功能包括计算当前位数的和和为下一位的和做进位

3.如果t不为0时证明仍有进位,若此时答案数组全部已经计算完毕则证明要在最高位加一

4.auto类型的设定可以让系统根据函数的返回值类型自动对C进行类型限制

#include <iostream>
#include <vector>
using namespace std;
vector<int> add(vector<int> &A,vector<int> &B)
{
	vector<int> C;
	int t = 0;
	if(A.size()<B.size())return add(B,A);
	for(int i = 0;i < A.size()||i < B.size();i ++ )
	{
		if(i < A.size())t += A[i];
		if(i < B.size())t += B[i];
		C.push_back(t%10);
		t /= 10; 
	}
	if(t)C.push_back(1);
	return C;
}
int main()
{
	string a,b;
	cin>>a>>b;
	vector<int> A,B;
	for(int i = a.size()-1;i >= 0;i -- )A.push_back(a[i]-'0');
	for(int i = b.size()-1;i >= 0;i -- )B.push_back(b[i]-'0');
	auto C = add(A,B);
	for(int i = C.size()-1;i >= 0;i -- )cout<<C[i];
	return 0;
}

Python解法

a=int(input())
b=int(input())
ans=a+b
print(ans)

高精度减法A-B

测试链接 

 洛谷P2142 高精度减法

源代码 

c++解法

代码重点

1.cmp函数,当大整数A和B的长度不相等时,比较二者长度即可。当二者长度相同时,从最高位依次向下比,当有其中一位不相等时,返回本位比较值即可。当各位都相等时,则返回ture。经过此函数的处理之后,若布尔函数返回true则为A>=B的情况。若布尔函数返回false则为A<B的情况

2.sub函数:t为借位情况,经过cmp函数的调整之后A一定是大于等于B的,所以从最低为开始减,若此位运算结果小于0,则加10再对10取余为本位结果,必向高位进行了借位,因此在下一位运算时-1。若此位运算结果大于等于0,则不进行借位,下次运算时t为0。在进行运算之后,要进行去掉前导0的运算

3.main函数,依旧本着方便运算的原则对于大整数进行倒叙存储,根据cmp函数结果进行分流,当true时为正,倒叙输出C即可。当false时为负,首先输出一个负号,再倒序输出即可

#include <iostream>
#include <vector>
using namespace std;
bool cmp(vector<int> &A,vector<int> &B)
{
	if(A.size() != B.size())return A.size() > B.size();
	for(int i = A.size() - 1;i >= 0;i -- )
	{
		if(A[i] != B[i])return A[i] > B[i];
	}
	return true;
}
vector<int> sub(vector<int> &A,vector<int> &B)
{
	vector<int> C;
	int t = 0;
	for(int i = 0;i < A.size();i ++ )
	{
		t += A[i];
		if(i < B.size())t -= B[i];
		C.push_back((t + 10) % 10);
		if(t < 0)t = -1;
		else t = 0;
	}
	while(C.size() > 1 && C.back() == 0)C.pop_back();
	return C;
}
int main()
{
	string a,b;
	cin>>a>>b;
	vector<int> A,B;
	for(int i = a.size() - 1;i >= 0;i -- )A.push_back(a[i] - '0');
	for(int i = b.size() - 1;i >= 0;i -- )B.push_back(b[i] - '0');
	if(cmp(A,B))
	{
		auto C = sub(A,B);
		for(int i = C.size() - 1;i >= 0;i -- )cout<<C[i];
	}
	else
	{
		cout<<"-";
		auto C = sub(B,A);
		for(int i = C.size() - 1;i >= 0;i -- )cout<<C[i];
	}
}

 Python3

a=int(input())
b=int(input())
ans=a-b
print(ans)

高精度乘法A*b和A*B

测试链接 

 洛谷P1303 A*B Problem

源代码 

c++解法(b为短数据)

代码重点

1.c++代码为大整数乘以小整数,因此对于洛谷的那道题来说只能通过40%的数据。高精度大乘小的原理在于A从最低为乘b乘到最高位,其中的t为进位,乘b之后当前位为(t + A[i] * b)%10,进位为((t + A[i] * b)%10)/10

2.其余依旧是大整数通过string和vector进行逆序存储逆序输出

#include <iostream>
#include <vector>
using namespace std;
typedef long long ll;
vector<int> mul(vector<int> &A,ll &b)
{
	vector<int> C;
	int t = 0;
	for(int i = 0;i < A.size() || t;i ++ )
	{
		if(i < A.size())t += A[i] * b;
		C.push_back(t % 10);
		t /= 10;
	}
	return C;
} 
int main()
{
	string a;
	ll b;
	cin>>a>>b;
	vector<int> A;
	for(int i = a.size() - 1;i >= 0;i -- )A.push_back(a[i] - '0');
	auto C = mul(A,b);
	for(int i = C.size() - 1;i >= 0;i -- )cout<<C[i];
	return 0;
}

Python3(B为长数据)

A*B太麻烦直接用Python3

a=int(input())
b=int(input())
ans=a*b
print(ans)

高精度除法A/b和A/B

测试链接 

洛谷P1480 A/B Problem

源代码 

 c++解法(b为短数据)

代码重点

1.与高精度加法、减法、乘法不同的是,高精度除法在div函数之中对于A的遍历顺序为从为到头,因存储时为倒叙存储,即为从最高位开始计算。所以,r作为一个余数来模拟人工算法,因一道题当中很可能不仅仅只对于除法进行考察,很有可能是四则运算,因此为了方便起见,C需要反转一下便于后面的输出,注意在反转之后要去掉前导零,因洛谷上的b为小整数小于10^9,因此能够通过所有数据测试点

2.部分题目可能要输出余数,因此将输出余数那一行的注释去掉就ok了

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
typedef long long ll;
vector<int> div(vector<int> &A,ll &b,ll &r)
{
	vector<int> C;
	r = 0;
	for(int i = A.size() - 1;i >= 0;i -- )
	{
		r = r * 10 + A[i];
		C.push_back(r / b);
		r = r % b; 
	}
	reverse(C.begin(),C.end());
	while(C.size() > 1 && C.back() == 0)C.pop_back();
	return C;
}
int main()
{
	string a;
	ll b,r;
	cin >> a >> b;
	vector<int> A;
	for(int i = a.size() - 1;i >= 0;i -- )A.push_back(a[i] - '0');
	auto C = div(A,b,r);
	for(int i = C.size() - 1;i >= 0;i -- )cout<<C[i];
	//cout<<endl<<r;//此处输出的为余数
	return 0;
}

Python3解法(B为长数据)

a=int(input())
b=int(input())
ans=a//b
print(ans)

高精度求和差积商余

c++太太太太太头疼了还是Python3比较暴力省事

a=int(input())
b=int(input())
print(a+b)
print(a-b)
print(a*b)
print(a//b)
print(a%b)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2266440.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何从 0 到 1 ,打造全新一代分布式数据架构

导读&#xff1a;本文从 DIKW&#xff08;数据、信息、知识、智慧&#xff09; 模型视角出发&#xff0c;探讨数字世界中数据的重要性问题。接着站在业务视角&#xff0c;讨论了在不断满足业务诉求&#xff08;特别是 AI 需求&#xff09;的过程中&#xff0c;数据系统是如何一…

elementPlus消息组件多按钮案例

let customClass zsl-el-message-box efb.messageBox({title: 操作提示,showConfirmButton: false,customClass,message: efb.VNode(div, null, [efb.VNode(style, null, .${customClass} .el-message-box__message {width: 100%;}),efb.VNode(div, null, hello world),efb.VN…

MATLAB符号计算-符号表达式基础运算操作

1.1.2符号变量取值域的限定 默认复数域 【例1-1-2】解不等式 1.1.3创建符号表达式 对符号对象进行各种运算&#xff08;算术运算、关系运算、逻辑运算&#xff09;&#xff0c;即可创建符号表达式。 1.算术运算与转置 【例1-1-3】 f5是f4的共轭转置 f6是f4的转置 2.关系…

使用Excel制作通达信自定义外部数据,安排!!!

Excel相信大家电脑上都有这个工具&#xff0c;相比敲编程代码&#xff0c;用这个去做自定义数据对大多数人&#xff0c;应该是比较友好的。自定义数据分为外部序列数据&#xff0c;看了一下内容理解起来比较多&#xff0c;分两期给大家介绍。为了照顾电脑基础薄弱的朋友&#x…

SwiftUI 入门趣谈:在文本框(TextField)内限制数字的输入

概述 虽然 SwiftUI 本身提供了海量内置的原生视图供我们使用&#xff0c;但对于某些情况我们还需要根据实际需求“量体裁衣、专属定制”。 在日常的撸码场景中&#xff0c;我们有时需要限制文本框&#xff08;TextField&#xff09;中数字内容的输入&#xff0c;如何又简单又快…

深入浅出 MyBatis | CRUD 操作、配置解析

3、CRUD 3.1 namespace namespace 中的包名要和 Dao/Mapper 接口的包名一致&#xff01; 比如将 UserDao 改名为 UserMapper 运行发现抱错&#xff0c;这是因为 UserMapper.xml 中没有同步更改 namespace 成功运行 给出 UserMapper 中的所有接口&#xff0c;接下来一一对…

基于c语言的union、字符串、格式化输入输出

结构体之共用体union 共用体也叫联合体&#xff0c;其关键词为union 与结构体不同的是&#xff0c;共用体所开辟的存储空间仅仅为其中最长类型变量的存储空间而不是全部变量的存储空间&#xff0c;由于同一内存单元在同一时间内只能存放其中一种的数据类型&#xff0c;因此在每…

IntelliJ Idea常用快捷键详解

文章目录 IntelliJ Idea常用快捷键详解一、引言二、文本编辑与导航1、文本编辑2、代码折叠与展开 三、运行和调试四、代码编辑1、代码补全 五、重构与优化1、重构 六、使用示例代码注释示例代码补全示例 七、总结 IntelliJ Idea常用快捷键详解 一、引言 在Java开发中&#xff…

AI开发:使用支持向量机(SVM)进行文本情感分析训练 - Python

支持向量机是AI开发中最常见的一种算法。之前我们已经一起初步了解了它的概念和应用&#xff0c;今天我们用它来进行一次文本情感分析训练。 一、概念温习 支持向量机&#xff08;SVM&#xff09;是一种监督学习算法&#xff0c;广泛用于分类和回归问题。 它的核心思想是通过…

Linux-----进程处理(子进程创建)

【尚硅谷嵌入式Linux应用层开发&#xff0c;linux网络编程&#xff0c;linux进程线程&#xff0c;linux文件io】https://www.bilibili.com/video/BV1DJ4m1M77z?p35&vd_source342079de7c07f82982956aad8662b467 main函数 fork创建进程 fork()参数 /*** brief 创建一个子进…

一种寻路的应用

应用背景 利用长途车进行货物转运的寻路计算。例如从深圳到大连。可以走有很多条长途车的路线。需要根据需求计算出最合适路线。不同的路线的总里程数、总价、需要的时间不一样。客户根据需求进行选择。主要有一些细节&#xff1a; 全国的长途车车站的数据的更新&#xff1a; …

2. FPGA基础了解--全局网络

前言 引入扇出的概念介绍FPGA中的全局网络为后续时序优化埋下伏笔 扇出 在FPGA设计中扇出是一个重要的概念&#xff0c;所谓的扇出就是一个控制信号所能控制的数据信号的总个数&#xff0c;比如ctrl信号的扇出就是16 reg ctrl 0; reg [15:0] out 0; always (posedge c…

Excel中一次查询返回多列

使用Excel或wps的时候&#xff0c;有时候需要一次查询返回多列内容&#xff0c;这种情况可以选择多次vlookup或者多次xlookup&#xff0c;但是这种做法费时费力不说&#xff0c;效率还有些低下&#xff0c;特别是要查询的列数过多时。我放了3种查询方法&#xff0c;效果图&…

智能化军事【五】精确制导武器智能化实现

文章目录 前言精确制导武器智能化实现基于深度学习实现的智能化功能基于强化学习实现的智能化功能强化学习深度强化学习 网络模型轻量化网络剪枝&#xff08;通道剪枝&#xff09;技术层剪枝权值量化技术低秩近似技术知识蒸馏技术强化学习联合训练 解决有效训练样本不足或获取困…

解锁高效密码:适当休息,让学习状态满格

一、“肝帝” 的困境 在当今竞争激烈的职场中&#xff0c;“肝帝” 现象屡见不鲜。超长工时仿佛成为了许多行业的 “标配”&#xff0c;从互联网企业的 “996”“007”&#xff0c;到传统制造业的轮班倒、无休无止的加班&#xff0c;员工们的工作时间被不断拉长。清晨&#xff…

asp.net 高校学生勤工俭学系统设计与实现

博主介绍&#xff1a;专注于Java&#xff08;springboot ssm 等开发框架&#xff09; vue .net php python(flask Django) 小程序 等诸多技术领域和毕业项目实战、企业信息化系统建设&#xff0c;从业十五余年开发设计教学工作 ☆☆☆ 精彩专栏推荐订阅☆☆☆☆☆不然下次找…

WebRTC服务质量(12)- Pacer机制(04) 向Pacer中插入数据

WebRTC服务质量&#xff08;01&#xff09;- Qos概述 WebRTC服务质量&#xff08;02&#xff09;- RTP协议 WebRTC服务质量&#xff08;03&#xff09;- RTCP协议 WebRTC服务质量&#xff08;04&#xff09;- 重传机制&#xff08;01) RTX NACK概述 WebRTC服务质量&#xff08;…

RTMW:实时多人2D和3D 全人体姿态估计

单位&#xff1a;上海AI实验室 代码&#xff1a;mmpose/tree/main/projects/rtmpose 系列文章目录 RTMO: 面向高性能单阶段的实时多人姿态估计 目录 系列文章目录摘要一、背景二、相关工作2.1 自上而下的方法。2.2 坐标分类。2.3 3D Pose 3 实验方法3.1.1 任务限制3.1.3训练技…

AI智能养站神器-SEO助理原创文章批量生成发布工具

很多站长最头疼的就是网站每天的内容更新&#xff0c;因为不知道写什么&#xff0c;采集被人的文章又会被定义为抄袭&#xff0c;而且现在伪原创已经没有多大的效果了&#xff0c;所以今天给大家分享的就是一款AI智能养战神器-SEO助理原创文章批量生成发布工具。 这款工具支持…

用Python开启人工智能之旅(三)常用的机器学习算法与实现

第三部分&#xff1a;常用的机器学习算法与实现 用Python开启人工智能之旅&#xff08;一&#xff09;Python简介与安装 用Python开启人工智能之旅&#xff08;二&#xff09;Python基础 用Python开启人工智能之旅&#xff08;三&#xff09;常用的机器学习算法与实现 用Pyt…