判断链表是否有回环 C


主要是思维,用快慢指针好一些,就是一个指针跑的快一个指针跑的慢,如果有回环,那么快的指针先完成一圈后会与慢指针再次相遇

c 复制代码
bool Node_ifhasCycle(struct Node *head) {
    Node* t = head;
    Node* q = head;

    while(t != NULL && q != NULL && q->next != NULL){
        t = t->next;
        q = q->next->next;

        if(t == q) return true;
    }

    return false;
}

一定要注意就是先判断指针是不是空再执行->next操作

相关推荐
Henry Zhu1232 分钟前
23种设计模式介绍以及C语言实现
c语言·开发语言·设计模式
LinHenrY12276 分钟前
初识C语言(数据在内存中的存储)
c语言·开发语言·算法
AI科技星11 分钟前
观察者与宇宙:描述如何创造物理实在
数据结构·人工智能·算法·机器学习·重构
zore_c12 分钟前
【C语言】数据结构——顺序表超详解!!!(包含顺序表的实现)
c语言·开发语言·数据结构·c++·经验分享·笔记·线性回归
发疯幼稚鬼13 分钟前
简单介绍二项队列及其实现
c语言·数据结构·算法
利刃大大17 分钟前
【JavaSE】十、ArrayList && LinkedList
java·链表·数组
子一!!18 分钟前
并查集(Union-Find)数据结构
java·数据结构·算法
2401_8414956420 分钟前
【LeetCode刷题】轮转数组
数据结构·python·算法·leetcode·数组·双指针·轮转数组
有泽改之_8 小时前
leetcode146、OrderedDict与lru_cache
python·leetcode·链表
im_AMBER9 小时前
Leetcode 74 K 和数对的最大数目
数据结构·笔记·学习·算法·leetcode