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

相关推荐
lightqjx1 分钟前
【C++】对set和map的使用
开发语言·数据结构·c++·stl
AI科技星34 分钟前
时空运动的几何约束:张祥前统一场论中圆柱螺旋运动光速不变性的严格数学证明与物理诠释
服务器·数据结构·人工智能·python·科技·算法·生活
别或许1 小时前
哈夫曼编码原理与应用详解
数据结构
集芯微电科技有限公司2 小时前
40V/3A高性能高集成三相BLDC驱动器具有电流及故障诊断功能(FLT)
c语言·数据结构·单片机·嵌入式硬件·fpga开发
liu****2 小时前
13.数据在内存中的存储
c语言·开发语言·数据结构·c++·算法
Unstoppable222 小时前
代码随想录算法训练营第 55 天 | 53. 寻宝(Prim + Kruskal)
数据结构·算法··kruskal·prim
liu****2 小时前
15.自定义类型:联合和枚举
数据结构·c++·剪枝
程序猿编码2 小时前
恶意软件分析工具:ELF二进制文件的感染与分析原理(C/C++代码实现)
c语言·c++·网络安全·信息安全·elf·shellcode
资深低代码开发平台专家2 小时前
通用编程时代正在向专用化分层演进
java·大数据·c语言·c++·python
laufing3 小时前
pycparser解析C代码构建AST
c语言·python·ast