免费建设网站公司哪家好刷排名seo
1、你有两个用链表代表的整数,其中每个节点包含一个数字。数字存储按照在原来整数中相反的顺序,使得第一个数字位于链表的开头。写出一个函数将两个整数相加,用链表形式返回和。
给出两个链表 3->1->5->null 和 5->9->2->null,返回 8->0->8->null
public ListNode addLists(ListNode l1, ListNode l2) {// write your code hereListNode dummy = new ListNode(-1);ListNode p1 = l1;ListNode p2 = l2;ListNode p = dummy;int flag = 0;while (p1 != null || p2 != null) {int temp = flag;if (p1 != null) {temp += p1.val;p1 = p1.next;}if (p2 != null) {temp += p2.val;p2 = p2.next;}if (temp > 9) {temp -= 10;flag = 1;} else {flag = 0;}p.next = new ListNode(temp);p = p.next;}if (flag == 1) {p.next = new ListNode(1);}return dummy.next;}
2、假定用一个链表表示两个数,其中每个节点仅包含一个数字。假设这两个数的数字顺序排列,请设计一种方法将两个数相加,并将其结果表现为链表的形式。
给出 6->1->7 + 2->9->5。即,617 + 295。
返回 9->1->2。即,912 。
思路:翻转之后转化成上面的问题,然后计算结果,然后在翻转一次就行了
public ListNode addLists2(ListNode l1, ListNode l2) {// write your code hereListNode l11 = reverse(l1);ListNode l22 = reverse(l2);ListNode p1 = l11;ListNode p2 = l22;ListNode dummy = new ListNode(-1);ListNode p = dummy;int flag = 0;while (p1 != null || p2 != null) {int temp = flag;if (p1 != null) {temp += p1.val;p1 = p1.next;}if (p2 != null){temp += p2.val;p2 = p2.next;}if (temp > 9) {temp -= 10;flag = 1;} else {flag = 0;}ListNode node = new ListNode(temp);p.next = node;p = p.next;}if (flag == 1) {ListNode node = new ListNode(1);p.next = node;}return reverse(dummy.next);} public ListNode reverse (ListNode head) {ListNode newhead = null;while (head != null) {ListNode temp = head.next;head.next = newhead;newhead = head;head = temp;}return newhead;}