单链表Ⅲ(LeetCode)

个人主页流年如梦

专栏《C语言》 《数据结构》

文章目录

一.相交链表

点击转跳👈

原题

🧐思路 :这道题要找两个链表的相交节点,核心方法是双指针拼接法;先用两个指针分别遍历两个链表,当一个链表遍历完后,就跳到另一个链表的头部继续遍历;这两个指针最终会同时到达相交节点(如果相交),或者同时到达NULL(如果不相交)

参考代码如下

c 复制代码
struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {
    struct ListNode *pA = headA, *pB = headB;
    while (pA != pB) {
        pA = pA ? pA->next : headB;
        pB = pB ? pB->next : headA;
    }
    return pA;
}

二.环形链表Ⅰ

点击转跳👈

原题

🧐思路 :这道题是判断链表是否有环,核心用快慢指针法;快指针每次走两步,慢指针每次走一步;如果链表有环,快指针一定会在环内追上慢指针;如果没环,快指针会先走到链表末尾

参考代码如下

c 复制代码
bool hasCycle(struct ListNode *head) {
    struct ListNode *slow = head, *fast = head;
    while (fast && fast->next) {
        slow = slow->next;
        fast = fast->next->next;
        if (slow == fast) {
            return true;
        }
    }
    return false;
}

三.环形链表Ⅱ

点击转跳👈

原题

🧐思路 :这道题的核心思路也是老方法快慢指针法;先用快慢指针判断链表是否有环(快指针走两步,慢指针走一步,相遇则有环);当相遇后,让一个指针回到链表头,两个指针同时以相同速度前进,再次相遇的节点就是入环点

参考代码如下

c 复制代码
struct ListNode *detectCycle(struct ListNode *head) {
    struct ListNode *slow = head, *fast = head;
    while (fast && fast->next) {
        slow = slow->next;
        fast = fast->next->next;
        if (slow == fast) {
            struct ListNode *p = head;
            while (p != slow) {
                p = p->next;
                slow = slow->next;
            }
            return p;
        }
    }
    return NULL;
}

四.随机链表的复制

点击转跳👈

原题

🧐思路 :这道题的核心思路是在原节点后插入复制节点 + 拆分链表 ;先遍历原链表,在每个节点后面插入它的复制节点;再遍历链表,给每个复制节点设置random指针(copy->random = old->random ? old->random->next : NULL);把链表拆分成原链表和复制链表两部分,返回复制链表的头节点

参考代码如下

c 复制代码
struct Node* copyRandomList(struct Node* head) {
    if (head == NULL) return NULL;
    struct Node* cur = head;
    while (cur) {
        struct Node* copy = (struct Node*)malloc(sizeof(struct Node));
        copy->val = cur->val;
        copy->next = cur->next;
        cur->next = copy;
        cur = copy->next;
    }
    cur = head;
    while (cur) {
        struct Node* copy = cur->next;
        copy->random = cur->random ? cur->random->next : NULL;
        cur = copy->next;
    }
    cur = head;
    struct Node* copyHead = head->next;
    while (cur) {
        struct Node* copy = cur->next;
        cur->next = copy->next;
        cur = cur->next;
        if (cur) {
            copy->next = cur->next;
        }
    }
    return copyHead;
}

🎯总结

这四道链表题,核心都是用双指针解决链表问题

  1. 复制随机链表 --> 通过在原节点后插入副本,再拆分链表实现深拷贝
  2. 环形链表判断 --> 快慢指针追逐法,相遇即说明有环
  3. 环形链表入环点 --> 快慢指针相遇后,再用同速指针定位入环点
  4. 相交链表 --> 双指针交叉遍历,相遇点就是相交节点

👀 关注 我们一路同行,从入门到大师,慢慢沉淀、稳步成长
❤️ 点赞 鼓励原创,让优质内容被更多人看见
⭐ 收藏 收好核心知识点与实战技巧,需要时随时查阅
💬 评论 分享你的疑问或踩坑经历,一起交流避坑、共同进步

相关推荐
鉴生Eric1 小时前
FOR算法中的AI智能体具体如何实现频谱感知和动态信道选择?请用技术术语详细说明其决策流程
人工智能·算法
量子炒饭大师1 小时前
【优化算法】双指针算法的「义体化」重构 ——【双指针】双指针算法中的指针是如何定义的?如何使用它进行一些简单的算法?
c++·算法·重构·优化算法·双指针
通信小呆呆2 小时前
ZC序列符号同步:多径信道下的四种经典算法
算法
机器学习之心HML2 小时前
粒子群算法求解速冻食品冷链配送路径优化问题,MATLAB代码
算法·matlab·冷链配送路径优化
fie88892 小时前
基于粒子群优化(PSO)算法的带STATCOM的IEEE 30节点系统最优潮流MATLAB实现
开发语言·算法·matlab
hele_two2 小时前
SDL2高效画实心圆的算法(一)
c++·算法·图形渲染
cheems95272 小时前
[算法手记] 动态规划,二叉树计数问题
算法·动态规划
贫民窟的勇敢爷们2 小时前
Scikit-learn算法:从入门到精通的机器学习工具箱
算法·机器学习·scikit-learn
Liangwei Lin3 小时前
LeetCode 155. 最小栈
java·javascript·算法