判断链表是否有回环 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操作

相关推荐
StandbyTime9 分钟前
C语言学习-菜鸟教程C经典100例-练习39
c语言
么么...29 分钟前
布隆过滤器详解:原理、实现与应用
java·数据结构·哈希算法·散列表
仰泳之鹅38 分钟前
【杂谈】C语言中的链接属性、声明周期以及static关键字
java·c语言·前端
Sheep Shaun1 小时前
深入理解红黑树:从概念到完整C++实现详解
java·开发语言·数据结构·c++·b树·算法
椒绿个屁1 小时前
进程与线程:进程基础
linux·c语言·进程基础
secondyoung1 小时前
队列原理与实现全解析
c语言·数据库·mysql·算法·队列
tobias.b1 小时前
408真题解析-2010-3-数据结构-线索二叉树
数据结构·链表·计算机考研·408真题解析
tobias.b1 小时前
408真题解析-2010-2-数据结构-双端队列
数据结构·计算机考研·408真题解析
旭意1 小时前
数据结构-红黑树和set
数据结构·c++·算法·蓝桥杯
宵时待雨1 小时前
数据结构(初阶)笔记归纳7:链表OJ
c语言·开发语言·数据结构·笔记·算法·链表