题解 | #两个链表的第一个公共结点#
两个链表的第一个公共结点
https://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46
struct ListNode *FindFirstCommonNode(struct ListNode* pHead1, struct ListNode* pHead2 ) {
//分别为两个链表分配两个指针来存放头节点;
struct ListNode *p = pHead1;
struct ListNode *p = pHead2;
//设置一个循环判断————直到两个指针中存放的内容完全相同时,即循环结束。
while(p!=q){
//第一个链表上的指针顺着链表的方向依次后移直到为空时,将头节点赋给这个指针。
if(p)
p = p->next;
else p = pHead;//这里注意一定要添加else,因为如果不添加程序会依次往后执行导致进入死循环。
//同理这样判断第二个链表上的指针。
if(q)
q = q->next;
else q = pHead2;
}
return p;//这里无论是返回p还是q都可以。
}
该题利用同步循环移位的方法可以解决,因为如果两个链表长度要么相同,此时两个指针以相同的速度会在一开始就会相遇,路程也是完全相同的。如果两个链表长度不相同,那么一定是前面不同,此时分别进入循环移位状态,当指针移到空时则重新将头节点赋给该指针,依次进行下去直到两者相等时则循环结束,返回该节点。如下表所示最后会在6相遇。
|
1
|
4 |
| 2 | 5 |
| 3 | 6 |
| 6 | 7 |
| 7 | 4 |
| 1 | 5 |
| 2 | 6 |
| 3 | 7 |
| 6 | 4 |
| 7 | 5 |
| 1 | 6 |
| 2 | 7 |
| 3 | 4 |
| 6 | 5 |
| 7 | 6 |
| 1 | 7 |
| 2 | 4 |
| 3 | 5 |
| 6 | 6 |


查看7道真题和解析