c++习题26-大整数加法

news2024/9/20 1:08:28

目录

一,题目

二,思路

三,代码 


一,题目

描述

求两个不超过200位的非负整数的和。

输入

有两行,每行是一个不超过200位的非负整数,可能有多余的前导0。

输出

一行,即相加后的结果。结果里不能有多余的前导0,即如果结果是342,那么就不能输出为0342。

样本输入 1
22222222222222222222
33333333333333333333

示例输出 1

55555555555555555555

二,思路

为了考虑到进位,长短不一样的两个字符串及便于发现规律,我将输入改成:

输入样例        

98765432123456
123456789

相应的输出样例如下

98765555580245

根据题目描述,可以先有下面的思路👇

  1. 200位的非负整数很大,推荐使用字符串的方法来解决问题,因此可以先定义字符数组变量int a[201],int b[201],int r[202],并通过键盘输入对字符数组a和b进行初始化,字符数组r用来输出(之所以数组r要比字符数组a和b多一个元素,主要还是考虑到进位问题,例如4×4=16,字符数组r就会有2个元素);

  2. 接着开始处理键盘输入的两个字符串a和b:

    a:98765432123456
    b:123456789      
    字符数组a和b的元素最多有201个,现在a有15个,b有10个(包含结束符'\0'),a和b剩下的部分都未被初始化,没有明确赋值,因此内容不确定,是随机的,可能是任何值。
  3. 在计算加减法,列竖式的时候都是将要计算的数先末尾对齐之后再进行一一计算,因此我脑海中第一个想到的就是将元素较少的字符串移位,让它和元素较多的字符串对齐,对齐之后就可以使得较少元素的字符串中本来不是倒数第一个的元素变成了倒数第一,其它元素也类推:
    98765432123456
             123456789
    之后再将两个字符串的倒数第一位相加,倒数第二位相加......但是移位很麻烦,因为需要先判断哪个是元素个数较少的字符串,之后再对相应的字符串进行操作,这个需要很多的步骤,所以我就将这个想法扼杀到摇篮里。接着我又想着在不移位的前提下,找到元素较少的字符串最后一个元素的下标(下标:元素较多的字符串的元素个数-元素较少的字符串的元素个数-1)再运算,显然这种方法也比较麻烦,因为需要找到元素较少的字符串。有兴趣的可以去尝试。这篇文章主要是用另外一种更加方便的方法。

  4. 考虑可以直接将这两个字符串分别使用reverse函数进行反转,就不需要用到移位:
    65432123456789
    987654321

    反转之后的两个字符串a和b从第一个字符开始遍历:
    ·因为需要将较长字符串中的所有元素遍历到,所以遍历长度为元素最多的字符串的元素个数
    ·在执行for循环之前先定义整型变量la存储字符串a的元素个数,整型变量lb存储字符串b的元素个数,使用max函数就可以得到for循环的循环次数m=max(la,lb);

    在遍历过程中先将对应字符转换成整数之后再相加:
    ·例如数组a的第一个元素是字符'6',如果想要得到整数6,就需要让字符'6'减去字符'0'(因为两个字符相减,是对应的整数ASCII码相减,所以得到的是整数)
    ·得到整数6之后,需要使用变量存储,不然这个值就会消失,因此使用整型d1变量存储字符数组a中每一次转换好的整数,整型d3变量存储字符数组b中每一次转换好的整数,因为d1和d2的值是在遍历字符串的时候需要用到的变量,所以可以直接放到for循环里面。

  5. 在第四步中已经可以得到两个字符串中参与的运算的每一个整数,接下来就需要考虑进位问题,在字符串a,b
    65432123456789
    987654321
    中,a[0]+b[0]=6+9=15,进1位,留下5。由于分别位于两个字符串中的第一个元素6和9(下标为0)前面没有元素,因此,它们前面的进位为0。由于第二个元素(下标为1)的两个元素a[1]+b[1]=5+8=13还得加上前面的进位1,既结果是14。因此需要在for循环外面定义一个整型变量  用来存储进位的数,初始值为0(最左边的两个数相加,进位为0)。
    所以两数运算的结果不仅有d1和d2还需要j,由于每一次的计算结果c不一样,可以将int c=d1+d2+j;放到for循环里面。

    【需要注意两点:】
    1,字符串中有字符的地方是初始化过的,但是没有初始化过的地方,内容随机且未知,需要手动的编写代码,将这部分的每一个字符作为数字0“返回”。
    之前提到strlen可以返回数组的元素个数,就已经告诉了我两个字符数组未初始化的地方:
    ·以字符数组a为例,当索引超过la时,后面的都是为初始化的部分,需要“返回”数字0。如果索引没有超过la,那么d1就是字符串a在遍历长度内的确切元素,可以通过循环变量作为索引找到。因此这里可以使用三元运算符(或称条件运算符)
    ·a?b:c;   →如果a为真,执行b操作,如果a为假,执行c操作。【三元运算符,先真后假】
    既:int d1=i<la?a[i]-'0':0;  // 如果索引没有超过字符数组a的元素个数,那么就返回存在的整数,否则返回整数0,让0参与运算。
    ·字符数组b也需要进行判断:int d2=i<lb?b[i]-'0':0; 

    2,在第四步中提到,要能够遍历完元素较多的字符串,需要遍历次数为m次,循环变量i从0开始,循环条件 i<m;  如果遍历到了字符串的最后一个元素,两个数相加有进位,那么这个进位就会丢失掉,循环条件设成i<=m就可以解决这个进位丢失的问题,但随之而来的就是多了前导0,那么,该如何解决?很简单,既然丢失的是进位,那么肯定是从进位变量 j 入手,当 j=1时,表示有进位,即使i已经大于m,但是仍需要继续循环,将计算的结果放到结果数组r中。所以循环条件需要修改成  i<m || j;
    i < m || j 的意思是:

    如果 i 小于 m,则条件为真。
    如果 j 非零(即 j 为真),则条件也为真。
    这意味着,循环将继续执行,直到 i 不再小于 m 并且 j 为零(假)。

  6. 通过第五步,已经计算出两字符串上指定位置的两数相加的结果,这个时候就可以将结果c存储到字符数组r中(在存结果的时候需要不是直接将c存进去,因为c此时可能是个两位数,需要对10取模,得到个位上的数,之后再将整数加上字符'0'转换成字符就行)

  7. 成功将一个结果存储到字符数组r中之后,存储进位数的变量 j   也需要改变值,如果c是两位数,既c/10>0。否则c/10==0,因此,直接令 j = c / 10; 即可。

  8. 在反转字符数组 r 并且在 字符数组  r 的最后一位加上结束符 之后,直接输出字符数组 r  就是所需要的结果。

三,代码 

#include <bits/stdc++.h>
using namespace std;
int main()
{
	char a[201],b[201],r[202];
	cin >>a>>b;
	reverse(a,a+strlen(a));
	reverse(b,b+strlen(b));
	int la=strlen(a),lb=strlen(b),m=max(la,lb),j=0,s=0;
	for (int i=0; i<m||j; i++)
	{
		int d1=(i<la)?a[i]-'0':0;
		int d2=(i<lb)?b[i]-'0':0;
		int c=d1+d2+j;
		r[s++]=(c%10)+'0';
		j=c/10;
	}
	reverse(r,r+s);
	r[s]='\0';
	cout<<r;
	return 0;
}

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

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

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

相关文章

论文合作容易踩坑?学术大咖为你揭秘合作研究中的潜规则

我是娜姐 迪娜学姐 &#xff0c;一个SCI医学期刊编辑&#xff0c;探索用AI工具提效论文写作和发表。 知乎上的话题&#xff0c;引发大家热议。因为如今合作发表论文在学术圈越来越普遍了。 随着低垂果实都发表了&#xff0c;大家在自己的领域越做越细分&#xff0c;再加上人工智…

WiFi标签注册(电脑版)

安装WiFi-Tool工具 需要windows系统电脑并且有WiFi功能 下载软件安装包&#xff1a;http://a.picksmart.cn:8088/picksmart/app/WiFi-Tool-Setup-V1.0.37.zip 配置操作流程 登录WiFi标签管理系统到设备管理-产品管理&#xff0c;复制“产品ApiKey”参数&#xff0c;打开“WiFi-…

day-42 分割字符频率相等的最少子字符串

思路 动态规划的思想&#xff0c;dp[i]表示从s[0]到s[i]这一子串的最少平衡子串数&#xff0c;当s[i]到s[n-1]是平衡字符串时&#xff0c;dp[i]dp[j-1]1,所以状态转换方程为dp[i]Math.min(dp[j-1]1)&#xff08;1<j<i&#xff09; 解题过程 判断是否为平衡字符串&#x…

《上海服饰》是什么级别的期刊?是正规期刊吗?能评职称吗?

​问题解答 问&#xff1a;《上海服饰》是不是核心期刊&#xff1f; 答&#xff1a;不是&#xff0c;是知网收录的正规学术期刊。 问&#xff1a;《上海服饰》级别&#xff1f; 答&#xff1a;省级。主管单位&#xff1a;上海世纪出版&#xff08;集团&#xff09;有限公司…

Leetcode 98 验证二叉搜索树 C++实现

Leetcode 98. 验证二叉搜索树 问题&#xff1a;给你一个二叉树的根节点 root &#xff0c;判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下&#xff1a; 节点的左子树只包含 小于 当前节点的数。节点的右子树只包含 大于 当前节点的数。所有左子树和右子树自身…

【Python入门】第2节 判断语句

&#x1f4d6;第2节 判断语句 ✅布尔类型和比较运算符✅if语句的基本格式✅if else 语句✅if elif else语句✅判断语句的嵌套 ✅布尔类型和比较运算符 布尔&#xff08;bool&#xff09;表达现实生活中的逻辑&#xff0c;即真和假 True表示真 False表示假。 True本质上是一…

代码随想录训练营 Day41打卡 动态规划 part08 121. 买卖股票的最佳时机 122. 买卖股票的最佳时机II 123. 买卖股票的最佳时机III

代码随想录训练营 Day41打卡 动态规划 part08 一、力扣121. 买卖股票的最佳时机 给定一个数组 prices &#xff0c;它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票&#xff0c;并选择在 未来的某一个不同的日子 卖出该股票。设计…

【计算机系统架构】从0开始构建一台现代计算机|时序逻辑、主存储器|第3章

博主简介&#xff1a;努力学习的22级计算机科学与技术本科生一枚&#x1f338;博主主页&#xff1a; Yaoyao2024往期回顾&#xff1a; 【计算机系统架构】从0开始构建一台现代计算机|二进制、布尔运算和ALU|第2章每日一言&#x1f33c;: 孤独和喧嚣都令人难以忍受。如果一定要忍…

【精选】基于B_S架构的智慧校园系统的设计与实现(全网独一无二,阿龙原创开发)

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…

5分钟搞定!最好用的6款写论文专用神器APP软件

在当今学术研究和写作领域&#xff0c;AI论文写作工具的出现极大地提高了写作效率和质量。这些工具不仅能够帮助研究人员快速生成论文草稿&#xff0c;还能进行内容优化、查重和排版等操作。以下是8款推荐的AI论文写作工具&#xff0c;包括千笔-AIPassPaper&#xff0c;帮助你更…

AOP自定义注解防重

Spring Boot 防重提交注解实现与实战示例 在Web开发中&#xff0c;防止用户重复提交表单是一个常见的需求。本文将详细介绍如何在Spring Boot中通过自定义注解和AOP技术实现防重提交功能&#xff0c;并提供一个完整的示例。 一、背景介绍 重复提交问题通常出现在用户在短时间…

来自OpenAI官网的Function calling介绍与最佳实践

学习如何将大型语言模型连接到外部工具。 介绍 函数调用允许您将模型如gpt-4o与外部工具和系统连接起来。这对于许多事情都很有用&#xff0c;比如为AI助手赋能&#xff0c;或者在你的应用程序与模型之间建立深度集成。 在2024年8月&#xff0c;我们推出了结构化输出功能。当…

8月27日笔记

活动目录的访问 AD Explorer LDAP&#xff08; Lightweight Directory Access Protocol&#xff0c;轻量目录访问协议&#xff09;是一种基于TCP/IP的应用层协议&#xff0c;用于访问和维护分布式目录信息服务。它允许用户在一个网络中查找和管理存储在目录服务中的信息。是在…

SCADA 系统开启车间智能可视化

在当今高速发展的工业时代&#xff0c;车间的高效运作与精准管理至关重要。然而在自动化设备、仪表、传感器等应用的现今&#xff0c;其产生的数据越来越庞大&#xff0c;要想将这些数据充分利用起来&#xff0c;并且形成更易分析的信息&#xff0c;则需要SCADA 系统来进行采集…

参数高效的迁移学习在自然语言处理中的应用

人工智能咨询培训老师叶梓 转载标明出处 迁移学习技术&#xff0c;尤其是针对大型预训练模型的微调&#xff08;fine-tuning&#xff09;&#xff0c;在诸多下游任务中展现出了卓越的性能。然而&#xff0c;当面临众多任务时&#xff0c;传统的微调方法存在参数效率低下的问题…

鸿蒙开发:深入浅出Stage模型(UIAbility组件)

&#x1f680;一、UIAbility组件 &#x1f50e;1.概述 HarmonyOS中的Stage模型是一种基于UIAbility组件的应用程序架构。UIAbility是HarmonyOS系统中用于构建用户界面的基本组件之一。它负责处理应用程序界面的显示和交互。 在Stage模型中&#xff0c;每个应用程序都有一个或…

【Qt笔记】QCommandLinkButton控件详解

目录 引言 一、概述 二、特性与属性 1. 属性 2. 样式 三、基本用法 1. 引入必要的头文件 2. 创建和配置 QCommandLinkButton 3. 布局管理 四、高级用法 1. 自定义绘制 2. 动态内容更新 五、代码解析示例 注意 总结 引言 QCommandLinkButton 是 Qt 框架中 QtWi…

招生简章如何制作为在线版的网址链接?

​随着互联网的高速发展&#xff0c;越来越多的学校和企业选择通过在线方式发布招生简章。这种趋势不仅方便了大量用户&#xff0c;还大大降低了传统纸质招生简章的制造成本。那么&#xff0c;如何制作一份吸引眼球的在线招生简章呢&#xff1f; 1.要制作电子杂志,首先需要选择…

leetcode_001_两数之和解析

两数之和解析 题目: 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。你可以假设每种输入只会对应一个答案&#xff0c;并且你不能使用两次相同的元素。你可以按任意顺序…

【解压即玩】使命de召唤4

《使命de召唤4》 立即下载&#xff1a;【chumenx.com】【解压即玩】使命de召唤4