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

相关推荐
三品吉他手会点灯4 小时前
C语言学习笔记 - 44.运算符和表达式 - 运算符2 - 除法与取余运算符
c语言·开发语言·笔记·算法
kkeeper~4 小时前
0基础C语言积跬步之动态内存管理
c语言·开发语言
艾iYYY4 小时前
string 类的模拟实现
android·服务器·c语言·c++·算法
Lsk_Smion4 小时前
力扣实训 _ [75].颜色分类 _ 杨辉三角
数据结构·算法·leetcode
jidaowansui5 小时前
P11375 [GESP202412 六级] 树上游走
数据结构·算法
hai3152475436 小时前
FlashAttention C语言(C++)实现(展示版)
c语言·开发语言·c++·人工智能·算法
wuminyu7 小时前
Java锁机制之Java对象重量级锁源码剖析
java·linux·c语言·jvm·c++
一切皆是因缘际会7 小时前
AI智能新时代
数据结构·人工智能·ai·架构
apocelipes8 小时前
GNU GCC 多版本函数扩展
c语言·c++·linux编程
辰痕~8 小时前
指针,结构体,动态内存分配
c语言