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

相关推荐
Severus_black15 小时前
【初阶数据结构】C语言实现堆(Heap),巨详细!
c语言·数据结构
Han_han91915 小时前
List系列集合:
数据结构·windows·list
永远自我15 小时前
matlab对c语言模块进行仿真
c语言·开发语言
Liangwei Lin15 小时前
LeetCode 394. 字符串解码
数据结构·算法
YuanDaima204816 小时前
动态规划基础原理与题目说明
数据结构·人工智能·python·算法·动态规划·手撕代码
大志出奇迹16 小时前
传输协议为大端,STM32为小端,数据传输的字节序问题
c语言·stm32·单片机·mcu·算法·rtos
_深海凉_16 小时前
LeetCode热题100-删除链表的倒数第 N 个结点
算法·leetcode·链表
枕星而眠16 小时前
Linux 共享内存与信号量全解析:原理、实践与避坑指南
linux·c语言·开发语言·后端·ubuntu
richard_yuu16 小时前
数据结构精讲:图的最短路径与关键路径
数据结构·算法
MegaDataFlowers17 小时前
102.二叉树的层序遍历
数据结构