当前位置: 首页 > news >正文

C语言/数据结构——每日一题(环形链表)

一.前言

今天在力扣上刷到一道链表题——环形链表https://leetcode.cn/problems/linked-list-cycle

想着和大家们分享一下。让我们直接开始今天的分享吧。、

二.正文

1.1题目描述

1.2题目分析

这道题是想让我们做出分析,该链表是不是带环链表,如果是带环链表就返回true。否则,就返回false。

这道题我们可以采用快慢指针的办法:定义一个快指针fast,一次走两个节点。再定义一个慢指针slow,一次只走一个节点。

如果不是带环链表,slow在之后的遍历中是永远不可能与fast相遇的。因此当slow和fast相遇后,就可以证明该链表是环形链表。这里咱们可以这样理解fast跑的快一些,早早的就进入了环内,当速度慢一些地slow进环以后,fast可能已经循环了好几圈了。此时就变成了fast追击slow的问题了。

为什么我们在这里肯定fast与slow一定相遇呢。

这里我们可以做一个假设,假设当slow刚进入环的时候,fast与slow的距离为N。

slow走一步。fast走两步。它们的距离就会有以下变化:

N

N-1

N-2

N-3

。。。。

N-n

因此一定存在某个瞬间N-n为0。即两个指针相遇。

那么如果fast一次走三步,fast和slow会相遇吗?

同理,fast走4步也是按此分析。

1.3代码实现

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/typedef struct ListNode ListNode;
bool hasCycle(struct ListNode *head) {if(head==NULL)return false;
ListNode* slow,*fast;
slow=fast=head;
while(fast&&fast->next){fast=fast->next->next;
slow=slow->next;
if(fast==slow)
{return true;
}}return false;
}

三.结言

题目分享写到这就结束了。帅哥美女们,觉得对自己有所帮助,能不能给我个三连。谢谢啦。

http://www.lryc.cn/news/348353.html

相关文章:

  • vue:网页icon无法显示
  • 电脑设置在哪里打开?Window与Mac双系统操作指南
  • 【linux】海量小文件的存储方案
  • 【SpringBoot整合系列】SpringBoot整合RabbitMQ-基本使用
  • MySQL————创建存储过程函数
  • 数据赋能(86)——数据要素:管理核心框架
  • 测试的基本概念
  • Python多线程加速-休眠部分线程
  • B+树(B+ Tree)
  • 【Linux】了解信号产生的五种方式
  • 【nuxt3国际化i18n】vue3+nuxt3+vite+TS国际化的正确做法
  • 数据库管理-第185期 23ai:一套关系型数据干掉多套JSON存储(20240508)
  • 7 zip 介绍
  • 前端页面 贴边拖拽 盒子
  • 【408真题】2009-10
  • WebSocket概述
  • 人机协同是虚拟与真实的协同
  • 【编程向导】Docker-常用命令
  • LeetCode题练习与总结:不同的二叉搜索树Ⅱ--95
  • idea SpringBoot + Gradle 环境配置到项目打包
  • 深入理解tengine的sysguard模块
  • 探索多模态LLM作为驾驶的世界模型
  • 掌握Vim:Linux系统维护的瑞士军刀 - 常用命令深度解析
  • C++数组和指针应用实例 -- 实现计算器
  • 【多电压流程 Multivoltage Flow】- 5.特定工具使用建议(6.Formality)
  • 力扣 72. 编辑距离 python AC
  • vue 发布项目
  • springBoot实现发送邮箱验证码 redis缓存源码
  • QT--4
  • 感染了后缀为.360勒索病毒如何应对?数据能够恢复吗?