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

相关推荐
曦月逸霜18 分钟前
第34次CCF-CSP认证真题解析(目标300分做法)
数据结构·c++·算法
吴声子夜歌3 小时前
OpenCV——Mat类及常用数据结构
数据结构·opencv·webpack
笑口常开xpr4 小时前
数 据 结 构 进 阶:哨 兵 位 的 头 结 点 如 何 简 化 链 表 操 作
数据结构·链表·哨兵位的头节点
XRZaaa5 小时前
常见排序算法详解与C语言实现
c语言·算法·排序算法
@我漫长的孤独流浪5 小时前
数据结构测试模拟题(4)
数据结构·c++·算法
jie188945758665 小时前
C++ 中的 const 知识点详解,c++和c语言区别
java·c语言·c++
彩妙不是菜喵7 小时前
算术操作符与类型转换:从基础到精通
c语言
JKHaaa8 小时前
几种简单的排序算法(C语言)
c语言·算法·排序算法
YGGP9 小时前
吃透 Golang 基础:数据结构之 Map
开发语言·数据结构·golang
weixin_4196583110 小时前
数据结构之栈
数据结构