c++习题27-大整数减法

目录

一,题目

二,思路

三,代码


一,题目

输入
共2行,第1行是被减数a,第2行是减数b(a > b)。每个大整数不超过200位,不会有多余的前导零。

输出
一行,即所求的差。

样例输入1

9999999999999999999999999999999999999
9999999999999

样例输出1

9999999999999999999999990000000000000

二,思路

这道题和之前的《c++习题26-大整数加法》思路类似,不同点就在于:

  • 加法涉及到的是进位(字符串a的元素个数可能比字符串 b少,在相加的过程中需要考虑到存储结果的字符数组 r 必须 要多一位),;
  • 减法是借位(题目有注明字符串a的元素个数比字符串b多,既a比b大,相减出来的结果一定是正数,并且存储结果的字符数组 r 的长度和字符数组a的长度一样),;
  • 在做减法运算的时候会出现很多个前导0(加法中就没有前导0,如果存储结果的字符数组 r 最左边出现了‘0’,那么肯定有进位1,加上去之后就会变成“10”)。

如下分析减法 9999-9998=1 :
1,两个数都反转
9999
8999
2,两数相减
1000
3,将存储输出结果的字符数组 r 反转
0001
4,消除最后一个元素 1 的前导0
因为前导0的个数是未知的,需要使用到while循环统计出前导0的个数,循环次数la-2次(不需要判断字符数组的最后一个元素,即使最后一个元素是0,也需要保留下来,作为结果输出),一旦遇到字符'0'就让统计前导0个数的变量 k 自增。
5,在输出字符数组的的时候,不需要前导0,因此需要从数组的 r 的  k 个 元素之后开始输出结果。

上面步骤所对应的简单代码描述:

  1. 反转字符数组,可以使用reverse函数: reverse(字符数组名,字符数组名+对应字符数组的元素个数):例如反转字符数组 char a[201];  →reverse(a,a+strlen(a));
  2. 通过题目描述,知道字符串a的元素个数肯定比字符串b多,因此,在遍历字符数组的时候,遍历的次数可以直接设置为字符数组a的元素个数既 int  la=strlen(a); (如果是加法的话还得使用max函数找到两个字符串中最多的元素个数既int m=max(a,b);)

    同时遍历两个字符串,从第一个元素下标0 开始 依次取出两个字符串中对应的元素:

    · 因为字符串a的元素个数最多,遍历的次数也是a的元素个数,不存在在遍历数组的时候,循环变量 i 大于a的元素个数的情况,所以字符数组a中的数字d1可以使用直接取到 int d1=a[i] -'0';
    · 但字符数组b在取值的时候就需要判断,如果循环变量 i  小于  b的元素个数 lb=strlen(b),那么也可以直接取到字符数组b中的数字d2,否则将未初始化的元素看成数字0:int d2=i<lb?b[i]-'0':0;
    · 接着将d1和d2相减,赋值给局部变量int c=d1-d2,前面提到,减法运算会有借位,在处理借位时,可以给一个全局变量 int j=0;因此,c的值还得需要再减去 j  ,当结果c小于0,为负数时,需要将c的值加上10,由负数变换成正数,并且,用于借位的 j 变量要赋值为1,表示发生了借位。否则,用于借位的变量 j 还是 默认为 0 ,更新j=0;
    · 在一轮运算结束之后,需要将 c 存入 存储输出结果的字符数组 r 中,因为 r 是 字符型数组变量,c是整型变量,将 c 的结果再加上字符 '0'就可以实现将整型数据转换成字符型数据。
  3. 使用reverse函数反转存储输出结果的字符数组 r
  4. 使用while循环,并定义一个循环变量int  k=0 。循环条件为 k小于字符数组 a 的元素个数 la-1(既k最大只能取到下标为la-2的元素,既倒数第三个元素  )以及  从第一个元素开始遍历输出结果数组时,如果有前导‘0’出现,那么就让 k 自增,统计前导0的个数。
  5. 给字符数组的末尾加上结束符'\0'之后,就可以使用cout<<r+k;输出结果。

三,代码

#include <bits/stdc++.h>
using namespace std;
int main() {char a[201], b[201], r[201];cin >> a >> b;reverse(a, a + strlen(a));reverse(b, b + strlen(b));int la = strlen(a), lb = strlen(b), j = 0, k = 0;for (int i = 0; i < la; i++) {int d1 = a[i] - '0';int d2 = (i < lb) ? (b[i] - '0') : 0;int c = d1 - d2 - j;if (c < 0) {c += 10;j = 1; } else {j = 0;}r[i] = c + '0';}reverse(r, r + la);while (k < la - 1 && r[k] == '0') {k++;}r[la] = '\0'; cout << (r + k) << endl;return 0;
} 

也可以使用sting来创建字符串,也是类似的思路,只是所使用得到的函数不一样而已,代码如下:

#include <bits/stdc++.h>
using namespace std;
int main() {string a,b,r;cin >> a >> b;int la = a.size(), lb = b.size(),j = 0;for (int i = 0; i <la; i++) {int d1 = a[la - 1 - i] - '0';int d2 = (i < lb) ? (b[lb - 1 - i] - '0') : 0;int c = d1 - d2 - j;if (c < 0) {c += 10;j = 1;} else {j = 0;}r.push_back(c + '0');}while (r.size() > 1 && r.back() == '0') {r.pop_back();}reverse(r.begin(), r.end());cout << r;return 0;
}

 有问题请在评论区留言或者是私信我,回复时间不超过一天。

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

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

相关文章

精密机械零件加工企业为制造业提供关键支撑

在当今高度发达的制造业中&#xff0c;精密机械零件加工企业扮演着至关重要的角色&#xff0c;以其精湛的工艺和严谨的态度&#xff0c;为制造业的各个领域提供着关键的支撑。 一、高精度制造&#xff0c;奠定产品质量基础 精密机械零件加工企业以其精湛的加工技术&#xff0c;…

android studio 设置gradle jdk

1. 左上角点击file 2. 按照如下点击&#xff1a; 3. 即可修改gradle jdk

灵办AI搜索引擎和文档总结工具

前言—— 在信息爆炸的时代&#xff0c;如何高效地获取和处理知识成为了每个人面临的挑战。随着人工智能技术的迅猛发展&#xff0c;本文将深入探讨这一创新工具的功能与优势&#xff0c;以及如何在日常生活和工作中充分利用它&#xff0c;开启智能化的信息获取新篇章。 点击…

nexus 清理 docker 镜像

下载配置 nexus-cli 看网上文档都用如下地址&#xff0c;但现在已经不能下载&#xff1a; wget https://s3.eu-west-2.amazonaws.com/nexus-cli/1.0.0-beta/linux/nexus-cli chmod x nexus-cli 在 github 上下载&#xff1a; wget https://github.com/heyonggs/nexus-cli/r…

【DSP+FPGA】基于DSP+FPGA XC7K325T与TMS320C6678的通用信号处理平台

DSP FPGA 协同处理架构板载 1 个TMS320C6678 多核DSP处理节点板载 1 片 XC7K325T FPGA处理节点板载 1 个FMC 接口板载4路SFP光纤接口FPGA 与 DSP 之间采用高速Rapid IO互联 基于FPGA与DSP协同处理架构的通用高性能实时信号处理平台&#xff0c;该平台采用1片TI的KeyStone系列多…

H5手机端调起支付宝app支付

1.调起APP页面如下 步骤 1.让后端对接一下以下文档&#xff08;手机网站支付通过alipays协议唤起支付宝APP&#xff09; https://opendocs.alipay.com/open/203/107091?pathHash45006f4f&refapi 2.后端接口会返回一个form提交表单 html&#xff1a;在页面中定义一个d…

Linux的远程登录教程(超详细)

我们在进行远程登录时要用的一种协议叫SSH&#xff0c;那什么叫SSH呢&#xff1f; SSH&#xff08;Secure Shell&#xff09;是一种网络协议&#xff0c;用于在不安全的网络中提供安全的远程登录和其他网络服务。它通过加密技术确保数据在传输过程中的机密性和完整性&#xff…

实训第三十二天(学习playbook-roles,脚本创建数据库和表,mycat读写分离)

1、roles&#xff08;角色&#xff09;介绍 roles(⻆⾊): 就是通过分别将variables, tasks及handlers等放置于单独 的⽬录中,并可以便捷地调⽤它们的⼀种机制。 假设我们要写⼀个playbook来安装管理lamp环境&#xff0c;那么这个 playbook就会写很⻓。所以我们希望把这个很⼤的…

从被动应对到主动防御:开发团队技术故障处理能力的全面升级,未雨绸缪,制胜未来!

开发团队如何应对突发的技术故障和危机&#xff1f; 网易云音乐 时间&#xff1a;2024年8月19日下午 问题&#xff1a; 服务器故障&#xff1a;网易云音乐网页端出现“502 Bad Gateway”报错&#xff0c;App也无法正常使用。影响&#xff1a;用户无法正常登录和使用app、we…

MAC +win10 笔记本, OBS 桌面音频不起作用 问题 总结

现象: MAC+WIN10笔记本,音频是好好的,可以听,但是OBS使用的时候,桌面音频条,保持静止,录制的视频,也没有系统声音。 问题排查 1、通常的OBS无法捕获音频解决方法 1)、 驱动问题,更新到最新驱动 2)、声音参数配置问题 3)、右侧小喇叭,音量合成器中, 4)、设…

【Word与WPS如何冻结首行首列及窗口】

1.Word如何冻结首行首列及窗口 microsoft word 中锁定表头是一项实用的功能&#xff0c;可让您在滚动文档时保持表头可见。这在处理大型文档或包含大量数据的表格时非常有用。php小编柚子将为您详细介绍 word 锁定表头位置的方法&#xff0c;帮助您轻松掌握这项实用技巧。 1.…

【STM32】驱动LCD

没买LCD屏&#xff0c;没有上机实践&#xff0c;只是学习了理论。 大部分图片来源&#xff1a;正点原子HAL库课程 专栏目录&#xff1a;记录自己的嵌入式学习之路-CSDN博客 目录 1 屏幕接口 2 屏幕驱动的基本步骤 3 8080时序的各信号线 4 8080的读和写 5 屏…

<Rust>egui学习之小部件(八):如何在窗口中添加滑动条slider部件?

前言 本专栏是关于Rust的GUI库egui的部件讲解及应用实例分析&#xff0c;主要讲解egui的源代码、部件属性、如何应用。 环境配置 系统&#xff1a;windows 平台&#xff1a;visual studio code 语言&#xff1a;rust 库&#xff1a;egui、eframe 概述 本文是本专栏的第八篇博…

使用redis模拟cookie-session,例子:实现验证码功能

目录 在前后端分离架构中不建议使用cookie-session机制实现端状态识别 所以我们可以使用redis来模拟session-cookie机制 下面我们通过实现验证码的功能来举例 第一步&#xff1a;了解前端要我们返回的数据变量名字&#xff0c;变量类型 1.封装code,data成一个result类&…

Linux网络配置实例,主机名和hosts映射

目录 linux网络配置实例 第一种方法&#xff08;自动获取&#xff09; 第二种方法&#xff08;指定ip&#xff09; 重启网络服务或者重启系统生效 设置主机名和hosts映射 设置主机名 设置hosts映射 主机名解析过程分析&#xff08;Hosts&#xff0c;DNS&#xff09; …

指针初阶(指针与二维数组)

0.二维数组特性 ①.存储格式 二维数组&#xff0c;在存储空间内的存储顺序是连续存储&#xff0c;按行优先存。 假设定义一个2X3的数组&#xff0c;其在存储空间的存储格式如下&#xff1a; ②.表示方法 且二维数组还有一个特性&#xff0c;例如有二维数组 a[3][2] ,那么 a[0] …

CleanClip for Mac v2.2.0 剪贴板历史管理软件正式激活版

CleanClip 是一款专为 Mac 用户设计的强大剪贴板历史管理工具。它能够自动保存您复制的内容,让您轻松访问和管理剪贴板历史记录,大大提高工作效率。 下载地址&#xff1a;CleanClip for Mac v2.2.0 剪贴板历史管理软件正式激活版 主要特点 自动保存剪贴板历史 CleanClip 会自…

SOMEIP_ETS_074: Wrong_Interface_Version

测试目的&#xff1a; 验证当设备&#xff08;DUT&#xff09;接收到一个包含错误接口版本的SOME/IP请求时&#xff0c;是否能够返回错误消息或忽略该请求。 描述 本测试用例旨在检查DUT在处理一个echoUINT8方法的SOME/IP消息时&#xff0c;如果消息中包含的接口版本不正确&…

[ACP云计算]易错题(原题)

ECS 1、 2、 3、 4、 5、 6、 7、 8、 9、 10、 11、 12、 13、 14、 15、 16、 17、 18、 19、 20、 21、 22、 23、 24、 25、 26、 27、 28、 29、 30、 31、 32、 33、 34、 35、 36、 37、 对象存储OSS 1、 2、 3、 4、 5、 6、 重点&#xff01;&#xff01;&#xff…

javaee、ssm(maven)、springboot(maven)项目目录结构以及编译后文件目录存放路径

javaee项目目录结构&#xff1a; src下的文件或者是源码编译后都会放在WebRoot&#xff08;项目根目录&#xff09;文件夹\WebRoot\WEB-INF\classes目录中。 编译后的文件夹目录如下&#xff1a; 以上为普通的javaee项目目录结构&#xff0c;同maven工程目录结构是不一样的。…