标签:def ret link lse tin 交点 linked 时间复杂度 solution
编写一个程序,找到两个单链表相交的起始节点。
例如,下面的两个链表:
A: a1 → a2 ↘ c1 → c2 → c3 ↗ B: b1 → b2 → b3
在节点 c1 开始相交。
注意:
null
./** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode(int x) { * val = x; * next = null; * } * } */ public class Solution { public ListNode getIntersectionNode(ListNode headA, ListNode headB) { if (headA == null || headB == null) { return null; } int lenA = len(headA); int lenB = len(headB); if (lenA>lenB) { while (lenA != lenB) { headA = headA.next; lenA--; } } else { while (lenA != lenB) { headB = headB.next; lenB--; } } while (headA != headB) { headA = headA.next; headB = headB.next; } return headA; } private int len(ListNode headA) { int len = 0; while (headA != null) { headA = headA.next; len++; } return len; } }
标签:def ret link lse tin 交点 linked 时间复杂度 solution
原文地址:https://www.cnblogs.com/airycode/p/9778224.html