两个数字字符串按照十进制规则相加,生成相应的字符串。
思想:两个指针指向两个字符串末尾,然后按照加法规则计算,用一个变量保存进位。最后有一方为空则用0补上,然后加上进位。最后将结果反转。
下面展示一些 内联代码片
。
// A code block
var foo =
// An highlighted block
//c++
string solution(string str1, string str2){
int m = str1.size() - 1;
int n = str2.size() - 1;
string ans;
int temp = 0;
while( m >= 0 || n >= 0){
int x = m >= 0 ? str1[m] : 0;
int y = n >= 0 ? str2[n] : 0;
int z = (x + y + temp) / 10;
temp = z / 10;
ans += to_string(z % 10);
—-m;
—-n;
}
reverse(ans.begin(), ans.end());
return ans;
}
这是一个把数学加法逻辑在字符串上实现的算法。
思维的转换,以及对字符串的操作都是需要熟练的