典型的字符串相加算法题有两类:一是用链表表示,而是直接用字符串表示。
2. 两数相加
给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。
如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。
您可以假设除了数字 0 之外,这两个数都不会以 0 开头。
示例:
**输入:**(2 -> 4 -> 3) + (5 -> 6 -> 4)
**输出:**7 -> 0 -> 8
**原因:**342 + 465 = 807
代码实现:
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
class Solution {
public ListNode addTwoNumbers(ListNode l1, ListNode l2){
ListNode head = new ListNode(0);
ListNode p=l1,q=l2, curr = head;
int carry = 0;
while(p!=null || q!=null){
int x = (p!=null) p.val:0;
int y = (q!=null) q.val:0;
int sum = carry+x+y;
carry = sum / 10;
curr.next = new ListNode(sum % 10);
curr = curr.next;
if(p!=null) p = p.next;
if(q!=null) q = q.next;
}
if(carry>0) //如果最高位大于10需要把多出的一位也插入
curr.next = new ListNode(carry);
return head.next; //带头节点时头节点不需要返回
}
}
415. 字符串相加
给定两个字符串形式的非负整数 num1 和num2 ,计算它们的和。
注意:
num1 和num2 的长度都小于 5100.
num1 和num2 都只包含数字 0-9.
num1 和num2 都不包含任何前导零。
你不能使用任何內建 BigInteger 库, 也不能直接将输入的字符串转换为整数形式。
官方代码:
class Solution {
public String addStrings(String num1, String num2) {
StringBuilder res = new StringBuilder("");
int i = num1.length() - 1, j = num2.length() - 1, carry = 0;
while(i >= 0 || j >= 0){
int n1 = i >= 0 ? num1.charAt(i) - '0' : 0;
int n2 = j >= 0 ? num2.charAt(j) - '0' : 0;
int tmp = n1 + n2 + carry;
carry = tmp / 10;
res.append(tmp % 10);
i--; j--;
}
if(carry == 1) res.append(1);
return res.reverse().toString();
}
}
本人根据上述链表题的思想给出的结题代码(思路大致相同,代码大同小异):
class Solution {
public String addStrings(String num1, String num2) {
if(num1.equals("0") && num2.equals("0")) return "0";
char[] ch1 = num1.toCharArray();
char[] ch2 = num2.toCharArray();
int carry = 0;
StringBuffer sb = new StringBuffer();
int idx1 = ch1.length-1, idx2 = ch2.length-1;
while(idx1 >= 0 || idx2>= 0){
int x = (idx1 >= 0) ? ch1[idx1]-'0' : 0;
int y = (idx2 >= 0) ? ch2[idx2]-'0' : 0;
int sum = carry + x + y;
carry = sum / 10;
sb.insert(0, sum% 10);
//System.out.print(sum % 10);
if(idx1 >= 0) idx1--;
if(idx2 >= 0) idx2--;
}
if(carry > 0) sb.insert(0, carry);
return sb.toString();
}
}