leetcode_002_addtwonumbers

package ywheel.leetcode._002_add_two_numbers;  
  
/** 
 * You are given two linked lists representing two non-negative numbers. The 
 * digits are stored in reverse order and each of their nodes contain a single 
 * digit. Add the two numbers and return it as a linked list. 
 *  
 * Input: (2 -> 4 -> 3) + (5 -> 6 -> 4) Output: 7 -> 0 -> 8 
 *  
 * @author ywheel 
 *  
 */  
public class AddTwoNumbers {  
    public ListNode addTwoNumbers(ListNode l1, ListNode l2) {  
        ListNode next = null;  
        ListNode head = null;  
        int decade = 0;  
        while (l1 != null || l2 != null || decade > 0) {  
            int l1_val = l1 == null ? 0 : l1.val;  
            int l2_val = l2 == null ? 0 : l2.val;  
            int sum = l1_val + l2_val + decade;  
            ListNode newNode = new ListNode(sum % 10);  
            decade = sum / 10;  
            if (next == null) {  
                next = newNode;  
                head = next;  
            } else {  
                next.next = newNode;  
                next = next.next;  
            }  
            l1 = l1 == null ? null : l1.next;  
            l2 = l2 == null ? null : l2.next;  
        }  
        return head;  
    }  
  
    public static void main(String[] args) {  
        AddTwoNumbers solution = new AddTwoNumbers();  
        // construct two inputs  
        ListNode l1 = new ListNode(2);  
        ListNode l11 = new ListNode(4);  
        ListNode l12 = new ListNode(3);  
        l1.next = l11;  
        l11.next = l12;  
        ListNode l2 = new ListNode(5);  
        ListNode l21 = new ListNode(6);  
        ListNode l22 = new ListNode(4);  
        l2.next = l21;  
        l21.next = l22;  
        ListNode resultNode = solution.addTwoNumbers(l1, l2);  
        if (resultNode != null) {  
            System.out.print(resultNode.val);  
        }  
        while (resultNode.next != null) {  
            resultNode = resultNode.next;  
            System.out.print("->" + resultNode.val);  
        }  
    }  
}  
  
/** 
 * Definition for singly-linked list. 
 */  
class ListNode {  
    int val;  
    ListNode next;  
  
    ListNode(int x) {  
        val = x;  
        next = null;  
    }  
}  

作者:ywheel
本文出处:http://blog.ywheel.com/post/2015/02/14/leetcode_002_addtwonumbers/
文章版权归本人所有,欢迎转载,但必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。