447. Add Strings
原文题目:
解题:
字符串的当做整数来做加法,其实就是大数加法的简化版本
思路:
1)考虑不同位数,如"1234"+“45”,需要先处理低两位,再处理num1的高两位
2)考虑进位,相加大于10时就要进位,进位值 = sum/10;
3)考虑最高位的进位,如“5099”+“4987”最后得到了五位的“10086”
AC代码:
class Solution {
public:
	string addStrings(string num1, string num2)
	{
		string re = "";
		int len1 = num1.length();
		int len2 = num2.length();
		int temp1,temp2,tempsum = 0;
		string tempstr;
		int carry = 0;
		int i = 0;
		//计算相同位的低位,同时保存进位到carry
		while(len1&&len2)
		{
			temp1 = num1[len1-1]-'0';
			temp2 = num2[len2-1]-'0';
			tempsum = temp1 + temp2 + carry;
			carry = tempsum / 10;
			tempstr = tempsum%10 + '0';
			re = tempstr + re; //注意re在后,若为re += tempstr,那么结果就需要翻转了
			len1--;
			len2--;
		}
		//计算num1或者num2剩余的位
		if(len1)
		{
			for(i = len1-1;i>=0;i--)
			{
				tempsum = num1[i]-'0' +carry;
				carry = tempsum / 10;
				tempstr = tempsum%10 + '0';
				re = tempstr + re;
			}
		}
		if(len2)
		{
			for(i = len2-1;i>=0;i--)
			{
				tempsum = num2[i]-'0' +carry;
				carry = tempsum / 10;
				tempstr = tempsum%10 + '0';
				re = tempstr + re;
			}
		}
		//剩余的位中如果还有进位,那么还需要加上
		if(carry)
		{
			tempstr = carry+'0';
			re = tempstr +re;
		}
		return re;
	}
};
447. Add Strings的更多相关文章
- 36. leetcode 415. Add Strings
		415. Add Strings Given two non-negative integers num1 and num2 represented as string, return the sum ... 
- [LeetCode] 415 Add Strings && 67 Add Binary && 43 Multiply Strings
		这些题目是高精度加法和高精度乘法相关的,复习了一下就做了,没想到难住自己的是C++里面string的用法. 原题地址: 415 Add Strings:https://leetcode.com/pro ... 
- 【leetcode】415. Add Strings
		problem 415. Add Strings solution: class Solution { public: string addStrings(string num1, string nu ... 
- LeetCode——Add Strings
		LeetCode--Add Strings Question Given two non-negative integers num1 and num2 represented as string, ... 
- LeetCode_415. Add Strings
		415. Add Strings Easy Given two non-negative integers num1 and num2 represented as string, return th ... 
- [LeetCode] Add Strings 字符串相加
		Given two non-negative numbers num1 and num2 represented as string, return the sum of num1 and num2. ... 
- LeetCode Add Strings
		原题链接在这里:https://leetcode.com/problems/add-strings/ 题目: Given two non-negative numbers num1 and num2 ... 
- [LeetCode] 415. Add Strings 字符串相加
		Given two non-negative numbers num1 and num2 represented as string, return the sum of num1 and num2. ... 
- Add Strings大整数加法十进制求和 & Add Binary二进制求和
		[抄题]: 以字符串的形式给出两个非负整数 num1 和 num2,返回 num1和 num2 的和. 比如一个50位+一个100位. 给定 num1 = "123",num2 = ... 
随机推荐
- Mybatis 系列3-结合源码解析properties节点和environments节点
			[Mybatis 系列10-结合源码解析mybatis 执行流程] [Mybatis 系列9-强大的动态sql 语句] [Mybatis 系列8-结合源码解析select.resultMap的用法] ... 
- mac一些设置
			Mac自带了的JDK6,安装在目录:/System/Library/Java/JavaVirtualMachines/1.6.0.jdk/下. JDK8则需要自己到Oracle官网下载安装对应的版本. ... 
- TensorFlow使用基础-Tensor
			使用 TensorFlow 之前你需要了解关于 TensorFlow 的以下基础知识 :• 使用图 (graphs) 来表示计算 .• 在会话 ( Session ) 中执行图 .• 使用张量 (te ... 
- SQL Server 2016:内存列存储索引
			作者 Jonathan Allen,译者 谢丽 SQL Server 2016的一项新特性是可以在“内存优化表(Memory Optimized Table)”上添加“列存储索引(Columnstor ... 
- solr使用cursorMark做深度分页
			深度分页 深度分页是指给搜索结果指定一个很大的起始位移. 普通分页在给定一个大的起始位移时效率十分低下,例如start=1000000,rows=10的查询,搜索引擎需要找到前1000010条记录然后 ... 
- 类似openDialog的弹窗
			html <modal title="这里是标题" hidden="{{modalHidden}}" bindconfirm="modalCon ... 
- PowerDesigner 物理数据模型(PDM) 说明
			ref: https://blog.csdn.net/tianlesoftware/article/details/6874067 一. PDM 介绍 物理数据模型(Physical Data ... 
- ActiveMQ核心技术
			消息中间件技术 一.ActiveMQ 1>生产消息,消费消息流程图 
- 接口详解例子代码(附Java1.8的接口新特性)
			接口,与抽象类类似但是区别也很大,他们都是标签,用来提醒父类一定要实现的类里创建抽象方法.而接口类可以implements 多个接口,抽象类则只能父类只能继承一个抽象类,与抽象不同的是它不是继承组合关 ... 
- 使用spacedesk实现两台笔记本的双屏显示
			转自:https://blog.csdn.net/qq_28106269/article/details/79297132 共屏软件:https://spacedesk.net/ 
