前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >蓝桥杯 基础练习 高精度加法

蓝桥杯 基础练习 高精度加法

作者头像
Meng小羽
发布2019-12-23 16:42:18
8100
发布2019-12-23 16:42:18
举报
文章被收录于专栏:Debug客栈

问题描述

输入两个整数ab,输出这两个整数的和。ab都不超过100位。

算法描述

由于ab都比较大,所以不能直接使用语言中的标准数据类型来存储。对于这种问题,一般使用数组来处理。

定义一个数组AA0用于存储a的个位,A1用于存储a的十位,依此类推。同样可以用一个数组B来存储b

计算c = a + b的时候,首先将A0与B0相加,如果有进位产生,则把进位(即和的十位数)存入r,把和的个位数存入C0,即C0等于(A0+B0)%10。然后计算A1与B1相加,这时还应将低位进上来的值r也加起来,即C1应该是A1、B1和r三个数的和.如果又有进位产生,则仍可将新的进位存入到r中,和的个位存到C1中。依此类推,即可求出C的所有位。

最后将C输出即可。

输入格式

输入包括两行,第一行为一个非负整数a,第二行为一个非负整数b。两个整数都不超过100位,两数的最高位都不是0。

输出格式

输出一行,表示a + b的值。

样例输入

20100122201001221234567890

2010012220100122

样例输出

20100122203011233454668012

C++算法

代码语言:javascript
复制
#include<cstdio>
 #include<iostream>
 #include<cstring>
 using namespace std;
 int a[401],alen,b[401],blen,c[400],clen;
 char st[400];
 int main()
 {
 int i,j,n,len;
 scanf("%s",st);
 alen= strlen(st);
 for(i=1;i<=alen;i++)
 a[i]= st[alen-i]-48;
 scanf("%s",st);
 blen= strlen(st);
 for(i=1;i<=blen;i++)
 b[i]= st[blen-i]-48;
 if(alen>blen) clen=alen;
 else clen=blen;
 for(i=1;i<=clen;i++)
 c[i]=a[i]+b[i];
 for(i=1;i<=clen;i++)
 {
 if(c[i]>=10)
 {
 c[i+1]=c[i+1]+ c[i]/10;
 c[i]=c[i]%10;
 }
 }
 if(c[clen+1]>0)clen++;
 for(i=clen;i>=1;i--)
 {
 printf("%d",c[i]);
 }
 printf("\n");
 return 0;
 } 

本文链接:https://cloud.tencent.com/developer/article/1558048

本文采用CC BY-NC-SA 3.0 Unported协议进行许可,转载请保留此文章链接

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 算法描述
  • 输入格式
  • 输出格式
  • 样例输入
  • 样例输出
  • C++算法
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档