llllmz

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

面试题 02.07. 链表相交C

利用链表的特性,如果相交的话,后面就不可能岔开!

你可以想象把他们有同一个尾巴,然后从尾巴往前看。

所以只要知道两个链表的长度,就可以在同一起跑线上一起比较了。

/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
int len(struct ListNode* list){
int i=0;
while(list){
i++;
list=list->next;
}
return i;
}
struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {
if(!headA||!headB) return NULL;
int a=len(headA);
int b=len(headB);
if(a==b){
if(headA==headB) return headA;
}
while(a!=b){
if(a>b){
headA=headA->next;
a--;
}else if(b>a){
headB=headB->next;
b--;
}
}
while(headA!=headB && headA && headB){
headA=headA->next;
headB=headB->next;
}
if(!headA||!headB) return NULL;
return headA;
}

结果:

posted on   神奇的萝卜丝  阅读(2)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· Vue3状态管理终极指南:Pinia保姆级教程
点击右上角即可分享
微信分享提示