华为測试 超长整数相加[通俗易懂]

华为測试 超长整数相加

大家好,又见面了,我是全栈君。

请设计一个算法完毕两个超长正整数的加法。

输入两个字符串数字

输出相加后的结果。string型

例子输入:99999999999999999999999999999999999999999999999999

                    1

例子输出:100000000000000000000000000000000000000000000000000

#include<iostream>
#include<string>
using namespace std;
string add(string num1,string num2);
int main()
{
	string add1,add2,anser;
	cin>>add1;
	cin>>add2;
	anser=add(add1,add2);
	cout<<anser<<flush;
	return 0;
}
string add(string add1,string add2)
{
	int MaxLen,jia1,jia2,jia,tenbit=0;
	char temp;
	string::iterator iter;
	string::reverse_iterator iter1,iter2;
	if(add1.size()>=add2.size())
	{
		MaxLen=add1.size();
		iter=add2.begin();
		add2.insert(iter,MaxLen-add2.size(),'0');
	}
	else
	{
		MaxLen=add2.size();
		iter=add1.begin();
		add1.insert(iter,MaxLen-add1.size(),'0');
	}
	 for(iter1=add1.rbegin(),iter2=add2.rbegin();iter1!=add1.rend(),iter2!=add2.rend();++iter1,++iter2)
	 {
		 if(iter1==add1.rend()-1 && iter2==add2.rend()-1)//处理最高位相加
		 {
			 jia1=*iter1-'0';
			 jia2=*iter2-'0';
			 jia=(jia1+jia2+tenbit)%10;
			 tenbit=(jia1+jia2+tenbit)/10;
			 *iter1=jia+'0';
			 if(tenbit>0)//若最高位有进位,向前产生数字1
				add1.insert(add1.begin(),'1');
		 }
		 else
		 {
			jia1=*iter1-'0';
			jia2=*iter2-'0';
			jia=(jia1+jia2+tenbit)%10;
			tenbit=(jia1+jia2+tenbit)/10;
			*iter1=jia+'0';
		 }
	 }
	return add1;
	
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116485.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 服务器如何存储图片(图片服务器搭建方案)

    参考:https://www.zhihu.com/question/20518854我们的ext4/dev/sda37299235847亿多个inode了。数据库直接存图片本身是SB的做法。比较好的方法是存图片md5,然后通过类似md52url获取图片的地址。至于图片存放,建议打散,打3级或5级。类似a/de/df/adedf***************.jpg…

    2022年4月10日
    332
  • Python画图爱心_python语言画爱心

    Python画图爱心_python语言画爱心都说程序员不浪漫,上次看到一个程序员小哥给自己老婆开发了一个专属的APP。其实程序员还有更多美好的事情可以做,比如,给你喜欢的妹纸,用代码的方式去表白(当然可能还有一些前戏啥的,自己结合实际场景再渲染下),直接上代码:print’\n’.join([”.join([(‘loveyou'[(x-y)%8]if((x*0.05)**2+(y*0.1)**2-1)**3-(x*0.05)**2*(y…

    2025年9月24日
    5
  • navicat 15 for mysql激活码[最新免费获取]「建议收藏」

    (navicat 15 for mysql激活码)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html0E14HXZ4QL-eyJsaWNlbnNlSW…

    2022年3月28日
    353
  • simhash java_雪花算法原理

    simhash java_雪花算法原理一篇不错的介绍simhash的文章,如下http://blog.csdn.net/chenguolinblog/article/details/50830948

    2022年9月1日
    2
  • 电信dns服务器哪个稳定,电信宽带dns设置哪个最快? dns设置哪个最好最快「建议收藏」

    电信dns服务器哪个稳定,电信宽带dns设置哪个最快? dns设置哪个最好最快「建议收藏」中国电信广州用户(包括番禺、增城、从化等区电信用户)“首选DNS服务器”为:61.144.56.101“备用DNS服务器”为:61.144.56.100这个经过测试确实是目前最快最有效的DNS服务器。2中国电信深圳用户“首选DNS服务器”为:202.96.128.86“备用DNS服务器”设置为:202.96.128.1663中国电信广东省其他地区用户(包括佛山、中山、江门、珠海、汕头等地区电信…

    2022年7月11日
    96
  • Python 之 pip安装 及 使用详解

    Python 之 pip安装 及 使用详解pip是啥  其实,pip就是Python标准库(ThePythonStandardLibrary)中的一个包,这个包比较特殊,用它可以来管理Python标准库(ThePythonStandardLibrary)中其他的包。pip支持从PyPI(https://pypi.org/),版本控制,本地项目以及直接从分发文件进行安装。pip是一个命令行程序。安装pip后,会向系统添加一…

    2022年6月11日
    90

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号