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

相关推荐
WongKyunban3 小时前
Linux中的线程是什么?
c语言
稚辉君.MCA_P8_Java3 小时前
Gemini永久会员 Java实现的暴力递归版本
java·数据结构·算法
LaoZhangGong1233 小时前
以太网HTTP数据包格式分析
c语言·stm32·网络协议·http·tcp·arp
星释4 小时前
Rust 练习册 67:自定义集合与数据结构实现
数据结构·算法·rust
lingggggaaaa5 小时前
免杀对抗——C2远控篇&PowerShell&有无文件落地&C#参数调用&绕AMSI&ETW&去混淆特征
c语言·开发语言·笔记·学习·安全·microsoft·c#
口袋物联5 小时前
设计模式之建造者模式在 C 语言中的应用(含 Linux 内核实例)
c语言·设计模式·建造者模式
切糕师学AI6 小时前
位带操作(Bit-Banding)是什么?
c语言·arm·嵌入式开发·cortex-m·位带操作
2301_807997386 小时前
代码随想录-day47
数据结构·c++·算法·leetcode
学习路上_write6 小时前
嵌入式系统bringup指南:软硬件调试
c语言·单片机·嵌入式硬件
say_fall6 小时前
C语言编程实战:每日一题 - day7
c语言·开发语言