LeetCode_2:两数相加

LeetCode第二题:

给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。

如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。

您可以假设除了数字 0 之外,这两个数都不会以 0 开头。

示例

输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)
输出:7 -> 0 -> 8
原因:342 + 465 = 807

  1. 遍历两个链表,并设置进位变量(carry)初始为0
  2. 如果链表不为空,则可以取到两个链表的节点的值(v1和v2)。如果有一个链表的节点为空,则该节点的值设为0
  3. 取到的两个值和进位变量carry 三个数相加,得到“和” sum(sum = v1 + v2 + carry)
  4. carry = sum / 10
  5. sum = sum % 10
  6. 创建新的节点,sum为新节点的值
  7. 遍历完后如果carry值为1,则新建一个节点值为1
  8. 返回头节点
class Solution {
    public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
    
        ListNode pre = new ListNode(0);
        ListNode cur = pre;
        
        int carry = 0;
        
        while(l1 != null || l2 != null){
            
            int v1 = l1 != null ? l1.val : 0;
            int v2 = l2 != null ? l2.val : 0;
            
            int sum = v1 + v2 + carry;
            
            carry = sum / 10;
            sum = sum % 10;
            
            cur.next = new ListNode(sum);
            cur = cur.next;
            
            if(l1 != null){
                l1 = l1.next;
            }
            if(l2 != null){
                l2 = l2.next;
            }
        }
        if(carry == 1){
            cur.next = new ListNode(carry);
        }
        return pre.next;   
    }
        
}

你可能感兴趣的:(算法)