链表|面试题 02.07.链表相交

cpp 复制代码
ListNode *getIntersectionNode(ListNode *headA, ListNode *headB) {
    ListNode *l = NULL, *s = NULL;
    int lenA = 0, lenB = 0, gap = 0;
    // 求出两个链表的长度
    s = headA;
    while (s) {
        lenA ++;
        s = s->next;
    }
    s = headB;
    while (s) {
        lenB ++;
        s = s->next;
    }

    // 求出两个链表长度差
    if (lenA > lenB) {
        l = headA, s = headB;
        gap = lenA - lenB;
    } else {
        l = headB, s = headA;
        gap = lenB - lenA;
    }

    // 尾部对齐
    while (gap--) l = l->next;
    // 移动,并检查是否有相同的元素
    while (l) {
        if (l == s) return l;
        l = l->next, s = s->next;
    }

    return NULL;
}

只要思路清晰,代码并不难敲。

嗯嗯,没想到怎样计算链表长度

一、出错点

1.计算两个链表长度时不知道简化,就一下子忘记怎样敲代码了

2.对于尾部对齐不够理解

二、理解后的思路

1.定义两个指针,长l,短s

2.初始化定义

3.计算两个链表的长度

4.求两个链表的差 (方便尾部对齐)

5.尾部对齐 ,因为相交链表部分只在尾部

6.移动,检查是否有相同的元素

代码随想录 (programmercarl.com)

三、总结

检查是否有相同的元素要注意题目的输入条件。

还是要多看代码,多敲代码,最重要的是要独立敲出代码!!

加强对题目的理解~

相关推荐
小白不想白a2 小时前
每日手撕算法--哈希映射/链表存储数求和
数据结构·算法
Doro再努力2 小时前
数据结构04:力扣顺序表3道例题解题思路与代码实现
c语言·数据结构
HY小海3 小时前
【C++】AVL树实现
开发语言·数据结构·c++
花月C3 小时前
高效查找数据的数据结构—MySQL 索引
数据结构·数据库·mysql
仰泳的熊猫3 小时前
LeetCode:701. 二叉搜索树中的插入操作
数据结构·c++·算法·leetcode
小L~~~6 小时前
2025吉比特-游戏引擎开发-一面复盘
数据结构·算法·游戏引擎
potato_may7 小时前
第18讲:C语言内存函数
c语言·数据结构·算法
仰泳的熊猫8 小时前
LeetCode:95. 不同的二叉搜索树 II
数据结构·c++·算法·leetcode
Nix Lockhart8 小时前
《算法与数据结构》第七章[算法4]:最短路径
c语言·数据结构·学习·算法·图论
xxxxxxllllllshi8 小时前
Cookie、Session、JWT、SSO,网站与 APP 登录持久化与缓存
java·开发语言·jvm·数据结构·缓存·面试