算法与数据结构(环形链表)

题目

思路

方法一:哈希表

我们可以这样想,若目标是环形链表,我们就会不断地在里面循环,若不是,最后肯定会遍历到nullpter。

我们可以遍历链表的所有节点,每当遍历到一个节点时,我们可以判断此节点之前是否被访问过。若被访问过,则说明一定是环形链表,返回true。直到遍历完整个链表,若都没被访问过,返回false。

方法二:快慢指针

我们可以定义两个指针,慢指针每次移动一步,快指针每次移动两步。

初始时,将慢指针定义在位置head,而快指针在位置head->next。这样一来,如果在移动的过程中,快指针反过来追上慢指针,就说明该链表为环形链表。否则快指针将到达链表尾部,该链表不为环形链表。

代码

方法一:哈希表

cpp 复制代码
class Solution {
public:
    bool hasCycle(ListNode *head) {
        unordered_set<ListNode*> s;
        while(head)
        {
            if(s.count(head))
                return true;
            s.insert(head);
            head = head->next;
        }
        return false;
    }
};

方法二:快慢指针

cpp 复制代码
class Solution {
public:
    bool hasCycle(ListNode *head) {
        if(head==nullptr || head->next==nullptr)
        return false;
        ListNode* fast=head->next;
        ListNode* slow=head;
        while(slow != fast)
        {
            if(fast == nullptr || fast->next == nullptr)
            return false;
            slow = slow->next;
            fast = fast->next->next;
        }
        return true;
    }
};
相关推荐
SsummerC10 小时前
【leetcode100】每日温度
数据结构·python·leetcode
jingshaoyou10 小时前
Strongswan linked_list_t链表 注释可独立运行测试
数据结构·链表·网络安全·list
逸狼13 小时前
【Java 优选算法】二分算法(下)
数据结构
云 无 心 以 出 岫16 小时前
贪心算法QwQ
数据结构·c++·算法·贪心算法
姜威鱼17 小时前
蓝桥杯python编程每日刷题 day 21
数据结构·算法·蓝桥杯
神里流~霜灭18 小时前
蓝桥备赛指南(12)· 省赛(构造or枚举)
c语言·数据结构·c++·算法·枚举·蓝桥·构造
扫地的小何尚18 小时前
NVIDIA工业设施数字孪生中的机器人模拟
android·java·c++·链表·语言模型·机器人·gpu
双叶83619 小时前
(C语言)单链表(1.0)(单链表教程)(数据结构,指针)
c语言·开发语言·数据结构·算法·游戏
学习编程的gas19 小时前
数据结构——队列的实现
数据结构
wuqingshun31415919 小时前
蓝桥杯 切割
数据结构·c++·算法·职场和发展·蓝桥杯