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

相关推荐
我要升天!9 小时前
C语言连接 MySQL:libmysqlclient 获取方式详解
c语言·开发语言·数据库·mysql·adb
潜创微科技9 小时前
CH9245:双 Type‑C 转 PD 芯片方案,便携显示与拓展坞的理想选择
c语言·开发语言
无限进步_10 小时前
C++ 继承机制完全解析:从基础原理到菱形继承问题
java·开发语言·数据结构·c++·vscode·后端·算法
不知名的忻10 小时前
并查集(QuickUnion)
java·数据结构·算法·并查集
leo__52010 小时前
基于时延的麦克风声源定位 - C实现
c语言·开发语言·算法
数智化精益手记局11 小时前
仓库安灯管理系统的异常响应机制:破解仓库安灯管理系统的跨部门协同难题
大数据·数据结构·人工智能·制造·精益工程
田梓燊11 小时前
力扣:138.随机链表的复制
算法·leetcode·链表
cen__y11 小时前
Linux04(重定向)
linux·服务器·c语言
小张成长计划..11 小时前
【C++】25:哈希表的实现
数据结构·哈希算法·散列表
zmj32032411 小时前
单片机内存在C 语言编译后的 “逻辑分区”
c语言·单片机·内存分区