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

华为測试 超长整数相加

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

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

输入两个字符串数字

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


相关推荐

  • groovy 定义map_groovy map

    groovy 定义map_groovy mapMap<String,String>ad_config=result.dataad_config.each{data->println(data.key)println(data.value)}pangolin_global_full_screen_video_idadmob_app_idadmob_banner_idadmob_interstitial_idadmob_rew…

    2022年9月14日
    1
  • jboss 配置文件_黑果小兵安装教程

    jboss 配置文件_黑果小兵安装教程一、Jboss下载:  1、点击 http://jbossas.jboss.org/downloads/找到合适的版本下载;  我这里是用的Jboss-as-7.1.1.Final版本,算是比较新的一个版本。    二、Jboss安装:  1、首先将下好的Jboss解压到自己想要存放的位置;  2、配置环境变量(非必要步骤),建议还是将环境变量配好,便于dos中命令操作;   …

    2022年9月27日
    2
  • 笔记本(无线网卡)配置虚拟机上网

    笔记本(无线网卡)配置虚拟机上网当我们安装了virtualbox或者VMware虚拟机,都会虚出一个虚拟网卡。如果我们使用的是网线上网,那么可以选择“网桥”的方式让虚拟机上网,这样可以保证虚拟机和主机之间互通,而且虚拟机也可以访问外网。这时,虚拟机可以使用dhcp也可以手工的方式指定ip。那么,如果笔记本使用的是无线网卡上网,那么就无法使用“网桥”的方式配置虚拟机上网了。这时,可以使用host-only的配置方式,同

    2022年5月19日
    44
  • Java工程师定位「建议收藏」

    Java工程师定位「建议收藏」Java工程师定位

    2022年4月22日
    40
  • 获得焦点与失去焦点事件

    获得焦点与失去焦点事件一介绍获得焦点事件(onfocus)是当某个元素获得焦点时触发事件处理程序。失去焦点事件(onblur)是当前元素失去焦点时触发事件处理程序。一般情况下,这两个事件是同时使用的。 二应用文本框获得焦点时改变背景颜色本示例是在用户选择页面中的文本框时,改变文本框的背景颜色,当选择其他文本框时,将失去焦点的文本框背景颜色恢复原始状态。 三代码

    2022年6月29日
    94
  • 大学《数据库系统》课程设计报告「建议收藏」

    大学《数据库系统》课程设计报告「建议收藏」湖南科技大学计算机科学与工程学院《数据库系统》课程设计题目:教学管理系统专业:计算机科学与技术年级:2017级班级:计科三班学号:170510323姓名:雨萱完成时间:2019年1月3日教务管理系统的分析与实现一.实验目的数据库系统课程设计是为了配合数据库原理及应用开发而…

    2022年5月12日
    23

发表回复

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

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