【手把手带你刷好题】—— 46.环形链表(双指针)

简介: 环形链表(双指针)

【前言】

今天是刷题打卡第46天!

...词穷了,总之加油鸭。


原题:环形链表(双指针)

示例1:

输入:head = [3,2,0,-4], pos = 1
输出:true
解释:链表中有一个环,其尾部连接到第二个节点。

示例2:

输入:head = [1], pos = -1
输出:false
解释:链表中没有环。

 

思路(快慢指针):

很简单,利用快慢指针来做就行了,如果链表有环,那么slow和fast一定会相遇。

代码执行:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
bool hasCycle(struct ListNode *head) {
    struct ListNode* slow = head;
    struct ListNode* fast = head;
    这里添加fast->next目的是防止空指针异常,因为循环体内fast一次走两步
    while(fast && fast->next)//之所以加上fast->next!=NULL这个条件,防止越界访问导致空指针异常
    {
        slow = slow->next;
        fast = fast->next->next;
        if(slow == fast)
        {
            return true;
        }
    }
    return false;
}


结语

今天是刷题打卡第46天!

加油吧少年。

 


相关文章
|
3月前
链表指针的传参,传值和传地址
本文讨论了链表操作中指针传参的问题,特别是指针的传值与传地址的区别,并提供了修正代码,以确保链表插入操作能正确地修改指针指向的地址。
22 1
链表指针的传参,传值和传地址
|
7月前
|
Java
环形数组链表(java)
环形数组链表(java)
|
3月前
|
C语言
无头链表二级指针方式实现(C语言描述)
本文介绍了如何在C语言中使用二级指针实现无头链表,并提供了创建节点、插入、删除、查找、销毁链表等操作的函数实现,以及一个示例程序来演示这些操作。
46 0
|
3月前
【数据结构】环形、相交、回文、分割、合并、反转链表
【数据结构】环形、相交、回文、分割、合并、反转链表
33 0
|
6月前
【数据结构OJ题】环形链表
力扣题目——环形链表
45 3
【数据结构OJ题】环形链表
|
6月前
【数据结构OJ题】复制带随机指针的链表
力扣题目——复制带随机指针的链表
59 1
【数据结构OJ题】复制带随机指针的链表
|
6月前
【数据结构OJ题】环形链表II
力扣题目——环形链表II
40 1
【数据结构OJ题】环形链表II
|
7月前
|
存储 算法 数据可视化
深入解析力扣160题:相交链表的解决方法(哈希表法与双指针法详细图解)
深入解析力扣160题:相交链表的解决方法(哈希表法与双指针法详细图解)
|
7月前
|
存储 算法 Java
【经典算法】Leetcode 141. 环形链表(Java/C/Python3实现含注释说明,Easy)
【经典算法】Leetcode 141. 环形链表(Java/C/Python3实现含注释说明,Easy)
67 2
|
6月前
|
Java 索引
力扣经典150题第五十六题:环形链表
力扣经典150题第五十六题:环形链表
40 0