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

华为測试 超长整数相加

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

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

输入两个字符串数字

输出相加后的结果。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)
上一篇 2022年1月20日 下午7:00
下一篇 2022年1月20日 下午7:00


相关推荐

  • 基于51单片机的流水灯设计

    基于51单片机的流水灯设计三个按键:A按键启动、B按键控制不同流水速度(低中高)、C按键设计思路一(未用中断):8个LED灯正极解电源,负极接单片机I/O口。死循环:设置P2口为11111110,使用左移函数,循环七次。同时每次位移中间加入延时函数。三个按键:A按键启动、B按键控制不同流水速度(低中高)、C按键控制流水灯暂停蜂鸣器长响:思路一:设置一个变量i,起初为0,按下A键后为1;当i为1进入死循环设置变…

    2022年5月3日
    137
  • 下列那个类有获取PropertyDescriptor实例的方法_java获取properties的值

    下列那个类有获取PropertyDescriptor实例的方法_java获取properties的值一、软件包java.beans   包含与开发beans有关的类二、PropertyDescriptor  PropertyDescriptor描述JavaBean通过存储器方法导出的一个属性构造方法:PropertyDescriptor(StringpropertyName,Class&lt;?&gt;beanClass)PropertyDe…

    2026年4月19日
    4
  • C中的LINQ

    C中的LINQ一 什么是 LINQ 二 用法 where 查询特定条件 usingSystem usingSystem Collections Generic usingSystem Linq classMainCla staticList Person personList newList Person newPerson Id 1 Name 小明 Age 20 Score 100 Person Person

    2026年3月18日
    1
  • 树莓派:pycharm远程控制

    树莓派:pycharm远程控制参考的文章和博客 http www icxbk com article detail 650 html 怎么配置 pycharm 专业版 https blog csdn net crazy scott article details 79233838 有一部分讲述怎么上传文件 https blog csdn net orangefly0

    2026年3月16日
    1
  • Pycharm配置数据源

    Pycharm配置数据源关于 pycharm 专业版配置数据源 1 打开 pycharm 点击 ide 右侧的 database 点击 找到你需要的数据源类型 2 点击 mysql 弹出数据库配置窗口 填写后 点击 TestConnecti 测试是否能够建立链接 关于 pycharm 社区版配置数据源由于社区版没有可以直接应用的功能 需要安装 DatabaseNavi 安装完毕后

    2026年3月27日
    3
  • 月之暗面放大招!首款自主智能体Kimi-Researcher登场

    月之暗面放大招!首款自主智能体Kimi-Researcher登场

    2026年3月12日
    2

发表回复

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

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