题解 | 大数加法
大数加法
https://www.nowcoder.com/practice/11ae12e8c6fe48f883cad618c2e81475
import java.util.*;
public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
* 计算两个数之和
* @param s string字符串 表示第一个整数
* @param t string字符串 表示第二个整数
* @return string字符串
*/
public String solve (String s, String t) {
// write code here
if(s==null || s == "") return t;
if(t==null || t == "") return s;
Stack<Character> ss = new Stack<Character>();
for(char c : s.toCharArray()) ss.add((Character)c);
Stack<Character> tt = new Stack<Character>();
for(char c : t.toCharArray()) tt.add((Character)c);
List<String> res = new ArrayList();
int lastV=0;
while(!(ss.isEmpty() && tt.isEmpty())) {
int add = lastV;
if (!ss.isEmpty()) add += (ss.pop()-'0');
if (!tt.isEmpty()) add += (tt.pop()-'0');
res.add(0,""+(add%10));
lastV = add/10;
}
if(lastV!=0) res.add(0,""+lastV);
return String.join("", res.toArray(new String[0]));
}
}