数据结构每日一题|判断链表是否有环型结构

仅记录学习思路 题目均来自力扣

思路:如果链表里面存在环形结构的话,则遍历链表是不会有头的,会一直循环下去。

画图理解可以看出在链表未来的某处一旦进入环形循环后就会一直在环形结构里无限绕圈,我们中学时期曾学过追击问题,所以我们可以想到我们的老朋友快慢两个指针都进入这个循环后相当于开始了一场封闭场地的追击问题。

我们可以设快指针的移动速度是B的两倍,在循环里,他们终究会在某一个节点相遇的。这个时候比较他们即可,可是比较什么呢,最开始我想到的是比较节点的值的大小,判断相等后再比较下一个节点,可是这就有一个问题,就算这真的是个圆环结构,那么比较到什么时候是个头呢,最后才想到直接比较两个指针,在第一次相遇的时候,快指针肯定是在前面的某个节点进入了环形结构重新返回了回来和慢指针相遇,即指向同一个地方,所以,如果直接比较二者是否相等即可判断。

cpp 复制代码
 //判断是否为环型链表
 bool hasCycle(struct ListNode* head) {
     ListNode* fast = head;//快指针 每次走两步
     ListNode* slow = head;//慢指针 每次走一步
     //如果有环,则快慢指针肯定会相遇,反之则不相遇。
    
     while (fast->next&&fast)
     {
         fast = fast->next->next;
         slow = slow->next;
         if (fast == slow)
         {
             return true;
         }
     }
     return false;
 }
相关推荐
ss27332 分钟前
2025新年源码免费送
java·前端·javascript·spring boot·后端·html
BingLin-Liu44 分钟前
备考蓝桥杯:顺序表详解(静态顺序表,vector用法)
数据结构
赵小左1 小时前
浅谈前端vue的自动导入插件unplugin-vue-components
前端·javascript·vue.js
前端啊龙1 小时前
eslint.config.js和.eslintrc.js有什么区别
开发语言·前端·javascript
无法长大1 小时前
el-upload on-preview 扩大预览事件点击范围
前端·javascript·css·vue.js·elementui·vue
7yewh1 小时前
【LeetCode】力扣刷题热题100道(6-10题)附源码 相交链表 回文链表 反转链表 合并链表 移动零(C++)
c语言·数据结构·c++·算法·leetcode·链表·贪心算法
DARLING Zero two♡2 小时前
【优选算法】Simulation-Phoenix:模拟算法的重生涅槃
java·数据结构·c++·算法·leetcode
bachelores2 小时前
axios的基本使用
javascript·json
花姐夫Jun2 小时前
el-date-picker日期时间选择器的选择时间限制到分钟级别
前端·javascript·vue.js
深度混淆2 小时前
C#,图论与图算法,有向图(Direct Graph)广度优先遍历(BFS,Breadth First Search)算法与源程序
数据结构·深度优先·图论·bfs·广度优先遍历