题解 | 大数加法
大数加法
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])); } }