LeetCode 2.两数相加

题目描述:
给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。
如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。
您可以假设除了数字 0 之外,这两个数都不会以 0 开头。
示例:
输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)
输出:7 -> 0 -> 8
原因:342 + 465 = 807

自己的想法:
新建一个ListNode l3储存求和之后的数据;
将l1与l2对应位置相加,在将超过十的部分存储到一个参数legacy中,剩下的取余给l3;
这时要想l1或l2其中一个为null了;
所以循环判断两者其一不为null就继续;
最后legacy不为零或者l1或l2不为null,就需要new l3.next;

代码:

class Solution{
	public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
		ListNode l3 = new ListNode(0);
		ListNode t1=l1,t2=l2,t3=l3;
		int legacy = 0;//用来储存需要进位的值
		
		while(t1!=null||t2!=null) {
			if(t1==null) {t3.val=t2.val+legacy;t2=t2.next;}//当t1为空时,只需要计算t2就行了
			else if(t2==null) {t3.val=t1.val+legacy;t1=t1.next;}
			else {t3.val = t1.val+t2.val+legacy;t1=t1.next;t2=t2.next;}
			legacy = t3.val/10;//计算当前t3的值需要向上进几
			t3.val = t3.val%10;
			if(t1!=null||t2!=null||legacy!=0)
			t3.next = new ListNode(legacy);
			t3=t3.next;
		}
		return l3;
	}
}
/*class ListNode {
	int val;
	ListNode next;
	ListNode(int x) { val = x; }
}*/
点赞