链表|面试题 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)

三、总结

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

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

加强对题目的理解~

相关推荐
我头发还没掉光~28 分钟前
P4147 玉蟾宫
数据结构·c++·算法
枕星而眠39 分钟前
栈(Stack)与队列(Queue)核心知识总结
c语言·数据结构·后端·链表
Little At Air1 小时前
LinuxOS阻塞队列模型(单生产者单消费者)
linux·数据结构·c++
铁皮哥2 小时前
【力扣题解】LeetCode 25. K 个一组翻转链表
java·数据结构·windows·python·算法·leetcode·链表
ZOOOOOOU2 小时前
云平台赋能门禁终端,打造智慧社区一体化管理
大数据·数据结构·架构
Severus_black3 小时前
【初阶数据结构】C语言实现堆(Heap),巨详细!
c语言·数据结构
Han_han9193 小时前
List系列集合:
数据结构·windows·list
Liangwei Lin4 小时前
LeetCode 394. 字符串解码
数据结构·算法
YuanDaima20484 小时前
动态规划基础原理与题目说明
数据结构·人工智能·python·算法·动态规划·手撕代码
_深海凉_4 小时前
LeetCode热题100-删除链表的倒数第 N 个结点
算法·leetcode·链表