C++基础算法----正整数高精度加减乘除

news2024/11/20 2:46:28

4、正整数高精度

​ 出现高精度的情况一般只有C++会出现,python会无限制,java有大整数,所以基本上不用考虑,一般会出现四种情况

  • 一个较大数A + 一个较大数B
  • 一个较大数A - 一个较大数B
  • 一个较大数A * 一个数
  • 一个较大数A / 一个数

这里补充一个知识 A<=10 和 len(A)<=10

前一个A 只能取 0-10

后一个A 是A的位数小于10 也就是说 A的取值范围为(0~9999999999)

4.1、高精度加法

​ 如果我们用数组去存储一个数,应该按下面这种方式去存储,方便去进位

image-20231021111157632

那么我们来看看模板

//模板
vector<int> add(vector<int>& A, vector<int> &B) {
	vector<int> c;

	int t = 0;//进位
	for (int i = 0; i <A.size()|| i<B.size(); i++)
	{
		//依次加上a,b上的位数
		if (i < A.size()) t += A[i];
		if (i < B.size()) t += B[i];
		// t%10就会得出该位的余数 比如 7+7 = 14 这里 14%10 = 4;
		c.push_back(t % 10);
		// 然后这里是看是否进位 没有进位就会变成0 有的话就会变成1
		// 例如 14/10 = 1; 9/10 = 0
		t /= 10;
	}
	//循环完看最高位是否进位 如果有的话就加上1
	if (t) c.push_back(1);
	return c;
}

​ 注意这里vector& A传进来的数组一定是一个倒着存储着大整数的数组,当然你遍历返回出来的数组也需要倒着输出,才能得到我们正常的显示。

4.2、高精度减法

在考虑高精度减法的时候,我们也是按照倒序的存储方式

image-20231021120933050

​ 这里需要注意的是,我们要先判断两个大整数谁大谁小的问题。

//判断是否 A>=B
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;
	for (int i = 0,t = 0; i < A.size(); i++)
	{
		t = A[i] - t;
		if (i < B.size()) t -= B[i];
		//这里(t +10) %10 是为了防止<0的情况出现
		c.push_back((t + 10) % 10);
		//判断是否需要借位 如果要借位那么就减去 
        //t的状态只有两种 0,1 1就是借位了 0就没借
		if (t < 0) t = 1;
		else t = 0;
	}
	//这里是去掉前面的0 如果结果为001 那么就去掉前面两个0
	//这里的位数是根据A的位数来的 例如 A 是 123  B是120 那么123-120 = 003
	while (c.size() > 1 && c.back() == 0) c.pop_back();
	return c;
}

4.3、高精度乘法

注意这里是一个高精度的整数 X 低精度的整数

//乘法模板
vector<int> mul(vector<int>& A, int b) {
	vector<int> c;
	int t = 0;//进位
	for (int i = 0; i < A.size() || t; i++) {
		if (i < A.size()) t += A[i] * b;
		//模10是为了得个位还剩多少
		c.push_back(t % 10);
		// 这里除以10为了得到进多少位
		t /= 10;
	}
	return c;
}

4.4、高精度除法

注意这里是一个高精度的整数 / 低精度的整数

//除法模板 商是c 余数是 r
vector<int> div(vector<int>& A, int b, int& r) { //r是引用的方式传回去
	vector<int> c; //商 
	r = 0;
	for (int i = A.size() - 1; i >= 0; i--) {
		//把当前位留出来加上下一位
		//例:12/11 = (1*10+2)/11 
		r = r * 10 + A[i];
		c.push_back(r / b);
		r %= b;
	}
	reverse(c.begin(), c.end());
	//去掉前导0
	while (c.size() > 1 && c.back() == 0) c.pop_back();

	return c;
}

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

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

相关文章

ubuntu系统由于英伟达显卡驱动问题黑屏或者其他报错开机无法进入系统解决办法!

背景&#xff1a; 硬件&#xff1a;CPU&#xff1a;AMD PRO 3955WX、硬盘&#xff1a;一块固态&#xff08;ubuntu&#xff09;一块固态&#xff08;windows&#xff09;双系统、英伟达丽台RTX4000显卡&#xff1b; 故障&#xff1a; 把显卡拆出来&#xff0c;拿到别的地方测…

分享一下商城小程序有哪些营销活动可以做的

随着移动支付的普及和电商行业的快速发展&#xff0c;商城小程序已成为消费者日常生活中不可或缺的一部分。小程序具有便捷性、即时性和个性化等特点&#xff0c;使得品牌商家能够更好地与消费者互动&#xff0c;提升销售额。本文将探讨商城小程序营销活动的几种形式&#xff0…

CentOS7日志文件及journalctl日志查看

一、日 志 文 件 说 明 tail /var/log/messages //系统启动后的信息和错误日志&#xff0c;是Red Hat Linux中最常用的日志之一 tail -f /var/log/secure //与安全相关的日志信息 tail /var/log/maillog //与邮件相关的日志信息 tail /var/log/cro…

8.canvas阴影设置

在canvas里面设置元素阴影相对来说比较简单&#xff0c;他有4个属性控制。 shadowOffsetX 描述阴影水平偏移距离的属性。 shadowOffsetY 描述阴影垂直偏移距离的属性。 shadowBlur 描述模糊效果程度的属性&#xff1b;它既不对应像素值也不受当前转换矩阵的影响。默认值是…

Python + Appium 自动化操作微信入门看这一篇就够了!

简介 Appium 是一个开源的自动化测试工具&#xff0c;支持 Android、iOS 平台上的原生应用&#xff0c;支持 Java、Python、PHP 等多种语言。 Appium 封装了 Selenium&#xff0c;能够为用户提供所有常见的 JSON 格式的 Selenium 命令以及额外的移动设备相关的控制命令&#…

Anaconda创建新的虚拟环境及Jupyter Notebok中、PyCharm中环境的使用

Anaconda创建新的虚拟环境 在windows开始菜单中【徽标键】&#xff0c;查找Anaconda文件夹并打开【Anaconda Prompt】 查看已有虚拟环境 conda env list1.创建 conda create --name mytest python3.7 # 创建一个名称为mytest&#xff0c;python版本为3.7的虚拟环境输入【…

【已解决】Word文档的“打开密码”在哪里设置?

我们知道&#xff0c;Word文档可以设置“打开密码”&#xff0c;保护文件不被随意打开&#xff0c;只有输入正确的密码才能打开文档。那这个“打开密码”要在哪里设置呢&#xff1f;不清楚的小伙伴往下看就知道啦。 在Word文档里&#xff0c;有两个路径可以设置“打开密码”。…

Activiti

文章目录 一、Activiti介绍&#xff08;一&#xff09;BPM&#xff08;一&#xff09;BPM软件&#xff08;一&#xff09;BPMN&#xff08;一&#xff09;使用步骤1、部署activiti2、流程定义2、流程定义部署2、启动一个流程实例2、用户查询待办任务2、用户办理任务2、流程结束…

文本生成图像工作简述5--对条件变量进行增强的 T2I 方法(基于辅助信息的文本生成图像)

目录 一、基于场景图的文本生成图像二、基于对话的文本生成图像三、基于属性驱动的文本生成图像四、基于边界框标注的文本生成图像五、基于关键点的文本生成图像六、其他基于辅助信息的文本生成图像 在传统的T2I方法中&#xff0c;常常使用一个固定的随机噪声向量作为输入&…

极智嘉(Geek+)柔性货箱到人拣选方案,助力Starlinks实现高效运营

近些年&#xff0c;电商业务席卷全球&#xff0c;一众企业蓬勃发展。比如沙特阿拉伯先进的物流与供应链解决方案供应商Starlinks的电子商务的销售额从6%增长到了23%。为满足日益增长的国际电商业务需求&#xff0c;以及订单交付时效性更高的要求&#xff0c;Starlinks与全球仓储…

中国人民大学与加拿大女王大学金融硕士——另辟蹊径往往能带来柳暗花明

莎士比亚曾说过&#xff0c;人生就是一部作品&#xff0c;谁有生活理想和实现的计划&#xff0c;谁就有好的情结和结尾&#xff0c;谁便能写得十分精彩和引人注目。人生之路&#xff0c;道阻且长。做好自己的规划&#xff0c;方能行稳致远。金融领域的你有计划在职读研&#xf…

双系统,grub系统选择界面字体大小调整!

背景&#xff1a; winodwsubuntu双系统&#xff0c;grub系统选择界面字体太小了&#xff0c;尤其是4K分辨率屏幕&#xff0c;影响观感&#xff0c;想要字体变大。 方法&#xff1a; 设置grub配置文件中的屏幕分辨率&#xff0c; 分辨率调小&#xff0c;字体就会变大&#xff…

formData对象打印不出来

用el-upload上传图片 以流的形式传给后台 所以用formData对象带数据 let formData new FormData() formData.append(name&#xff0c;monkey7) console.log(formData) 明明已经把数据append进去了 console.log在控制台却打印不出 后来发现他得用formData.get("xxx"…

【unity3D】Scroll Rect组件—制作下滑列表

&#x1f497; 未来的游戏开发程序媛&#xff0c;现在的努力学习菜鸡 &#x1f4a6;本专栏是我关于游戏开发的学习笔记 &#x1f236;本篇是unity的Scroll Rect组件 Scroll Rect组件 基础知识详细说明案例演示——制作一个简单的下滑框扩展 介绍&#xff1a;Scroll Rect组件是用…

如何搭建开源ERP平台Odoo并实现公网远程访问?——“cpolar内网穿透”

文章目录 前言1. 下载安装Odoo&#xff1a;2. 实现公网访问Odoo本地系统&#xff1a;3. 固定域名访问Odoo本地系统 前言 Odoo是全球流行的开源企业管理套件&#xff0c;是一个一站式全功能ERP及电商平台。 开源性质&#xff1a;Odoo是一个开源的ERP软件&#xff0c;这意味着企…

如何在Potplayer中使用公网访问群晖WebDav?

文章目录 1 使用环境要求&#xff1a;2 配置webdav3 测试局域网使用potplayer访问webdav4 内网穿透&#xff0c;映射至公网5 使用固定地址在potplayer访问webdav ​ 国内流媒体平台的内容让人一言难尽&#xff0c;就算是购买了国外的优秀作品&#xff0c;也总是在关键剧情上删删…

[答疑]QQ泡妞序列图上的参数名称对吗?

DDD领域驱动设计批评文集 做强化自测题获得“软件方法建模师”称号 《软件方法》各章合集 第五元素 2023-10-11 14:18 潘老师&#xff0c;这两个画圈的地方对吗&#xff1f; 还有&#xff0c;这里有“邮件附件”&#xff0c;是否可以改为“活动计划”呢&#xff1f; UMLChin…

【会议征稿通知】2024第四届神经网络、信息与通信工程国际学术会议(NNICE 2024)

2024第四届神经网络、信息与通信工程国际学术会议&#xff08;NNICE 2024&#xff09; 2024 4th International Conference on Neural Networks, Information and Communication Engineering 2024第四神经网络、信息与通信工程国际学术会议&#xff08;NNICE 2024&#xff0…

软件开发模式对比(瀑布、迭代、螺旋、敏捷)

1、瀑布模型是由W.W.Royce在1970年最初提出的软件开发模型&#xff0c; 瀑布式开发是一种老旧的计算机软件开发方法。 瀑布模型式是最典型的预见性的方法&#xff0c;严格遵循预先计划的需求分析、设计、编码、集成、测试、维护的步骤顺序进行。 步骤成果作为衡量进度的方法&a…