高精度减法【c++】超详细讲解

news2025/1/11 10:15:43

前言

大家学过高精度加法之后,可能已经知道高精度减法的实现方法了吧

如果你还没有学过高精度加法的话,请点击这里(很详细的)—>高精度加法【C++实现】详解

最大的问题

最大的问题莫过于负数问题了。其他方法和加法一样。

负数处理

如果a<b, a - b的算式就成了这样(12 - 431= -419):

             

把答案倒过来是-299,这显然与我们的正确答案-113不符。如果b-a呢,就是这样子:

                

这时我们加一个负号,答案就是-319,与正确答案完全符合。

核心思路

所以处理负数我们分为两种情况:

1.a > b
直接计算就好了,对位相减, 做好借位就没问题。

2.a < b
这个时候是负数,所以要做 b - a ,保证结果是整数,同时用一个变量(我用的fu记录,fu==1表示结果为负)记录正负。

核心代码如下:

if(checkzf())//checkzf()为判断a是否大于b,如果大于或等于返回true,否则返回false 
{
	for(int i = 0; i < lena; i++)
	{
		if(a[i] < b[i]) //如果当前位的被减数小于减数,就要退位 
		{
			a[i + 1]--;//比i高的以为被借走1,所以a[i+1]-- 
			a[i] += 10;//本位+10 
		}
		result[i] = a[i] - b[i];//当前位计算结果为被减数-减数 
	}
} 
else
{
	fu = true;//如果a<b,输出b-a,不要忘记加负号 
	for(int i = 0; i < lenmax; i++)//原理同a-b一样,在这里就不再赘述了。 
	{
		if(b[i] < a[i]) 
		{
			b[i + 1] -= 1;
			b[i] += 10;
		}
		result[i] = b[i] - a[i];
	}
}

 算法过程

1.倒序输入

2.判断正负,如果a<b,结果为-(b-a), 否则结果为a-b

3.输出负号

4.倒序输出结果

代码

代码如下:

#include <bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
int a[N], b[N], result[N];
string s1, s2;
int lena, lenb, lenmax;
bool fu = false;
bool checkzf()//checkzf()为判断a是否大于b,如果大于或等于返回true,否则返回false  
{
	int flag = 0;//标记是否相等 
	if(lena > lenb) return true;//如果a的长度大于b的长度,说明a>b,返回true 
	if(lena < lenb) return false;//如果a的长度大于b的长度,说明a<b,返回false 
	if(lena == lenb)//如果长度相等,有一个a[i]>b[i], 就说明a > b, 否则说明a<b 
	{
		for(int i = lena - 1; i >= 0; i--)
		{
			if(a[i] > b[i]) 
			{
				flag = 1;//标记 
				return true;
			}
			if(a[i] < b[i]) 
			{
				flag = 1;//标记 
				return false;
			}
		}
	}
	if(flag == 0) return true;//如果不大也不小,就是相等了。 
}
int main()
{
	cin >> s1 >> s2;
	lena = s1.size();
	lenb = s2.size();
	lenmax = max(lena, lenb);
	//倒序存储 
	for(int i = 0; i < lena; i++) a[i] = s1[lena - i - 1] - '0';
	for(int i = 0; i < lenb; i++) b[i] = s2[lenb - i - 1] - '0';
	if(checkzf())//checkzf()为判断a是否大于b,如果大于或等于返回true,否则返回false 
	{
		for(int i = 0; i < lena; i++)
		{
			if(a[i] < b[i]) //如果当前位的被减数小于减数,就要退位 
			{
				a[i + 1]--;//比i高的以为被借走1,所以a[i+1]-- 
				a[i] += 10;//本位+10 
			}
			result[i] = a[i] - b[i];//当前位计算结果为被减数-减数 
		}
	} 
	else
	{
		fu = true;//如果a<b,输出b-a,不要忘记加负号 
		for(int i = 0; i < lenmax; i++)//原理同a-b一样,在这里就不再赘述了。 
		{
			if(b[i] < a[i]) 
			{
				b[i + 1] -= 1;
				b[i] += 10;
			}
			result[i] = b[i] - a[i];
		}
	}
	//删除前缀多余的0 
	int tmp = lenmax;
	while(result[tmp] == 0 && tmp > 0) tmp--;
	if(fu) printf("-");//如果fu = true,输出负号
	//倒序输出 
	for(int i = tmp; i >= 0; i--) cout << result[i];
    return 0;
}

请您点赞关注加收藏,谢谢您的阅读,您的鼓励是我更新最大的动力

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

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

相关文章

4.二级缓存解析

文章目录1. 二级缓存配置2. 二级缓存结构3. 二级缓存命中条件4. 缓存空间的理解5. 二级缓存执行流程二级缓存也称作是应用级缓存&#xff0c;与一级缓存不同的&#xff0c;是它的作用范围是整个应用&#xff0c;而且可以跨线程使用。所以二级缓存有更高的命中率&#xff0c;适合…

从南丁格尔图到医学发展史

可视化中&#xff0c;前端用于表现不同类目的数据在总和中的占比的场景&#xff0c;往往会采用饼图。 针对数据大小相近&#xff0c;南丁格尔图的呈现会更加美观。 南丁格尔图&#xff0c;又称玫瑰图&#xff0c;是由弗罗伦斯南丁格尔发明。 弗洛伦斯南丁格尔 开创了护理事业…

二、django中的路由系统

django中的路由系统 django中路由的作用和路由器类似&#xff0c;当一个用户请求Django站点的一个页面时&#xff0c;是路由系统通过对url的路径部分进行匹配&#xff0c;一旦匹配成功就导入并执行对应的视图来返回响应。 django如何处理请求 当一个请求来到时&#xff0c;d…

SpringSecurityOauth2架构Demo笔记

总体分为SpringSecurityOauth2授权码模式演示和密码模式演示 一直下一步,依赖手动导入,SpringBoot版本改成2.2.5.RELEASE,JDK版本1.8 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xml…

Open3D 点云投影至指定球面(Python版本)

文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 假设球体的相关参数:中心为 C ( x c , y c , z c ) C(x_c,y_c,z_c)

【数据结构和算法】栈—模拟实现Stack和栈相关算法题

文章目录栈的定义Stack模拟实现相关算法题1.栈的压入弹出序列2.逆波兰表达式(后缀表达式)⭐1.什么是逆波兰表达式?如何转换成逆波兰表达式逆波兰表达式如何计算3.有效的括号总结栈的定义 栈作为一种数据结构&#xff0c;是一种只能在一端进行插入和删除操作的特殊线性表。它按…

华为MPLS跨域C2方案实验配置

MPLS隧道——跨域解决方案C1、C2讲解_静下心来敲木鱼的博客-CSDN博客_route-policy rr permit node 10 if-match mpls-labelhttps://blog.csdn.net/m0_49864110/article/details/127634890?csdn_share_tail%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId…

深度学习——长短期记忆网络LSTM(笔记)

长短期记忆网络LSTM&#xff1a; ①隐变量模型存在长期信息保存和短期输入缺失问题&#xff0c;解决方法是LSTM ②发明于90年代 ③使用效果和GRU差别不大&#xff0c;但是实现起来复杂 1.长短期记忆网络 ①忘记门Ft&#xff1a;将值朝0减少 ②输入门It&#xff1a;是否忽…

最容易理解的并查集详解

并查集 并查集&#xff0c;在一些有N个元素的集合应用问题中&#xff0c;我们通常是在开始时让每个元素构成一个单元素的集合&#xff0c;然后按一定顺序将属于同一组的元素所在的集合合并&#xff0c;其间要查找一个元素在哪个集合中。 比如下面这幅图&#xff0c;总共有 10 …

MySQL之存储过程

MySQL存储过程1、基本介绍1.1、介绍存储过程&#xff1a;1.2、特点1.3、基本语法1.3.1、delimiter1.3.1、创建存储过程1.3.2、调用存储过程1.3.3、查看存储过程1.3.4、删除存储过程2、变量2.1、系统变量2.1.1、查询(会话、全局、模糊、精确)2.1.2、设置系统变量2.2、用户定义变…

IB学生必须具备的三大特质

以往的专栏亦提及过&#xff0c;修读IB课程要面对几大挑战。而要应对这些挑战&#xff0c;IB学生须具备以下三大条件&#xff1a; 时间管理能力 IBDP 首先&#xff0c;要对时间分配掌握得很好。两年的IB预科课程非常紧凑&#xff0c;不但每科都有其内部评核&#xff08;Interna…

VMware17虚拟机安装Ubuntu最新版本(Ubuntu22.04LTS)详细步骤

目录 一、概述 二、下载Ubuntu 22.04.1 LTS 三、在VMware虚拟机下安装Ubuntu22.04 四、配置网络 一、概述 Ubuntu是基于Linux内核开发的&#xff0c;免费下载&#xff0c;使用和分享的开源系统。如果需要在Linux下开发程序&#xff0c;这是一个很好的选择。本文介绍了Ubuntu最…

【问题解决】Tomcat启动服务时提示Filter初始化或销毁出现java.lang.AbstractMethodError错误

问题背景 最近在开发项目接口&#xff0c;基于SpringBoot 2.6.8&#xff0c;最终部署到外置Tomcat 8.5.85 下&#xff0c;开发过程中写了一个CookieFilter&#xff0c;实现javax.servlet.Filter接口&#xff0c;代码编译期正常。部署到外置Tomcat 8.5.85 下&#xff0c;在控制…

【Java寒假打卡】Java基础-类加载器

【Java寒假打卡】Java基础-类加载器概述类加载时机类加载的过程-加载类加载的过程-链接类加载的过程-初始化类加载器的分类类加载器-双亲委派模型类加载器-常用方法概述 负责将字节码文件加载到内存中 类加载时机 创建类的实例对象调用类的类方法访问类或者接口的类变量&am…

SymPy符号运算库与latex数学公式

SymPy符号运算库与latex数学公式sympylatexsympy SymPy是一个用于以符号运算为主的符号数学的Python库。它的目标是成为一个全功能的计算机代数系统(CAS)&#xff0c;同时保持代码尽可能的简单&#xff0c;以便易于理解和易于扩展。SymPy完全是用Python编写的。 官网地址:http…

【linux kernel】Linux设备驱动模型 | bus

文章目录一、导读二、与总线相关的数据结构&#xff08;2-1&#xff09;struct bus_type&#xff08;2-2&#xff09;struct subsys_private三、总线的初始化四、总线的操作接口&#xff08;4-1&#xff09;总线的注册&#xff08;4-2&#xff09;总线的注销&#xff08;4-3&am…

Linux的基本使用在Linux上部署程序

linux概述 Linux严格意义来说只是一个"操作系统内核"&#xff0c;一个完整的操作系统 操作系统内核 配套的应用程序 由于 Linux 是一个完全开源免费的内核&#xff0c;因此有些公司/开源组织又基于 Linux 内核&#xff0c;提供了不同的配套程序&#xff0c;这就构…

GAN“家族”又添新成员——EditGAN,不但能自己修图,还修得比你我都好

导语&#xff1a;从风格迁移到特征解耦、语言概念解耦&#xff0c;研究人员正通过数学和语言逐步改善GAN的功能。作者 | 莓酊编辑 | 青暮首先想让大家猜一猜&#xff0c;这四张图中你觉得哪张是P过的&#xff1f;小编先留个悬念不公布答案&#xff0c;请继续往下看。生成对抗网…

【蓝桥杯】历届真题 时间显示(省赛)Java

【问题描述】 小蓝要和朋友合作开发一个时间显示的网站。在服务器上&#xff0c;朋友已经获取了当前的时间&#xff0c;用一个整数表示&#xff0c;值为从1970年1月1日O0:00:00到当前时刻经过的毫秒数。 现在&#xff0c;小蓝要在客户端显示出这个时间。小蓝不用显示出年月日&a…

Allegro如何灌铜操作指导

Allegro如何灌铜操作指导 在做PCB设计平面层的铜皮时候,会需要用到灌铜的操作,如下图 灌铜可以让铜皮自动沿着Antietch画指定网络的铜皮 具体操作如下 点击Add Line命令选择Anti Etch的层面,比如Anti Etch画在L2层,线宽设置为40mil