[链表OJ题 7] 环形链表

简介: [链表OJ题 7] 环形链表

题目来源:

力扣 141. 环形链表

题目描述


代码实现:

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

思路分析:

本题是要看链表是否成环,那我们就定义快、慢两个指针,快指针一次走两步,慢指针一次走一步。如果链表是成环的,快指针一定就可以追赶上慢指针,重合后就是成环的;如果链表不成环,那我们的快指针就会走到空。



实现过程:

1、使用快慢指针,初始化都指向原链表的头,慢指针一次走一步,快指针一次走两步;

2、在循环的时候我们加上一条判断语句,fast == slow 时,就说明链表是成环的;

3、如果快指针走到了空,或者快指针的 next 为空时,那就说明链表是不成环的。


*** 本篇结束 ***

相关文章
|
2月前
数据结构——链表OJ题
数据结构——链表OJ题
|
2月前
|
存储 C语言 索引
环形链表、环形链表 II、有效的括号​​​​​​​【LeetCode刷题日志】
环形链表、环形链表 II、有效的括号​​​​​​​【LeetCode刷题日志】
|
26天前
|
索引
【力扣】142. 环形链表 II
【力扣】142. 环形链表 II
|
26天前
|
C语言 C++ 索引
【力扣】141. 环形链表、160. 相交链表、206.反转链表、234. 回文链表
【力扣】141. 环形链表、160. 相交链表、206.反转链表、234. 回文链表
|
1月前
|
算法 C语言 索引
环形链表(快慢指针)
环形链表(快慢指针)
|
2月前
|
算法 索引
LeetCode刷题---142. 环形链表 II(双指针-快慢指针)
LeetCode刷题---142. 环形链表 II(双指针-快慢指针)
|
2月前
|
算法 索引
LeetCode刷题---141. 环形链表(双指针-快慢指针)
LeetCode刷题---141. 环形链表(双指针-快慢指针)
|
2月前
|
算法 Java 索引
[Java·算法·简单] LeetCode 141. 环形链表 详细解读
[Java·算法·简单] LeetCode 141. 环形链表 详细解读
26 0
|
3月前
|
算法
顺序表、链表相关OJ题(2)
顺序表、链表相关OJ题(2)
|
3月前
|
存储 算法
顺序表、链表相关OJ题(1)
顺序表、链表相关OJ题(1)