力扣题解-链表类|字符串相加的两类题型解析

典型的字符串相加算法题有两类:一是用链表表示,而是直接用字符串表示。

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();
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值