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

华为測试 超长整数相加

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

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

输入两个字符串数字

输出相加后的结果。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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mybatisPlus填坑之逻辑删除

    mybatisPlus填坑之逻辑删除网上大部分的关于mybatisPlus的逻辑删除的配置介绍都是有问题的,原因可能是官网已经做了更新!!!错误如图:正确的配置是:SpringBoot配置方式: application.yml加入配置(如果你的默认值和mp默认的一样,该配置可无): yml文件(区别是多了一个路径db-config,同学们细看了) mybatis-plus:global-c…

    2022年5月5日
    168
  • 盘点值得互联网创业者学习的十大做事风格

    盘点值得互联网创业者学习的十大做事风格中国互联网通过第19次互联网报告得出很多数据,综合成一句话就是:“发展速度惊人。”面对如此庞大的市场,国外网络巨头虎视眈眈,总想找机会跨进国门,却因为不了解中国互联网运营规范及网民的习惯,或是犹豫不决或是屡遭搁浅。  而与此同时,国内众多网站正在疯狂抢夺这块蛋糕。在这些网站的背后出谋划策的人都是大众较熟悉的,他们的思路以及做事风格,值得现在的互联网创业者学习、借荐,有相似者可对号入座。

    2022年8月20日
    11
  • Scrapy项目 – 数据简析 – 实现腾讯网站社会招聘信息爬取的爬虫设计

    Scrapy项目 – 数据简析 – 实现腾讯网站社会招聘信息爬取的爬虫设计一、数据分析截图本例实验,使用Weka3.7对腾讯招聘官网中网页上所罗列的招聘信息,如:其中的职位名称、链接、职位类别、人数、地点和发布时间等信息进行数据分析,详见如下图:图1-1Weka3.7分析界面图1-2职位数据ZeroR分析界面图1-3数据聚类分析界面图1-4数据Visualize分析界面二、数据分析结论由图2-1可知,随着应聘人数的…

    2022年5月2日
    56
  • git已经提交的文件回复忽略「建议收藏」

    git已经提交的文件回复忽略「建议收藏」将文件加入到忽略文件中使用命令,已提交的文件如何恢复忽略git rm –cached 文件git rm –cached -r 文件夹git rm –cached .push到远程

    2022年8月8日
    5
  • word2vec 原理

    word2vec 原理转自:http://www.cnblogs.com/iloveai/p/word2vec.htmlSVD分解:低维词向量的间接学习既然基于co-occurrence矩阵得到的离散词向量存在着高维和稀疏性的问题,一个自然而然的解决思路是对原始词向量进行降维,从而得到一个稠密的连续词向量。第一个出场的对原始矩阵进行降维的方法是奇异值分解(SVD)。SVD的基本思想是,通过将原co-occurrence…

    2022年5月16日
    44
  • 无阻塞情况connect生产EINPROGRESS错[通俗易懂]

    无阻塞情况connect生产EINPROGRESS错[通俗易懂]今天的游戏开发client测试程序,非常多,因为出现client。后connect成功。代码证recv系统调用。后来发现,可能是由于socket默认模式被阻止,这将使很多client接处于链接却不能数据传输状态。后来改动socket为非堵塞模式,但在connect的时候,发现返回值为-1,刚開始以为是connect出现错误,但在server上看到了链接是ESTABLISED…

    2022年7月16日
    17

发表回复

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

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