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

【leetcode】环形链表✚环形链表II

大家好,我是苏貝,本篇博客带大家刷题,如果你觉得我写的还不错的话,可以给我一个赞👍吗,感谢❤️
在这里插入图片描述


目录

  • 1.环形链表
    • 解题
    • 拓展:
  • 2.环形链表II

1.环形链表

点击查看题目

在这里插入图片描述

解题

思路:

在这里插入图片描述

bool hasCycle(struct ListNode *head) {struct ListNode *slow=head;struct ListNode *fast=head;while(fast&&fast->next){slow=slow->next;fast=fast->next->next;if(fast==slow)return true;}return false;
}

拓展:

1
慢指针一次走2步,快指针一次走3步,可以解决上面的题目吗?
可以的,因为它们也只是相差了1步,证明同上

2

慢指针一次走1步,快指针一次走3步,走4步,…n步行吗?下面用慢指针一次走1步,快指针一次走3步来证明
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


2.环形链表II

点击查看题目

在这里插入图片描述

思路:

在这里插入图片描述

struct ListNode *detectCycle(struct ListNode *head) {struct ListNode *slow=head;struct ListNode *fast=head;while(fast&&fast->next){slow=slow->next;fast=fast->next->next;//1.找到相遇的节点if(slow==fast){//让meet从相遇节点开始走struct ListNode *meet=slow;while(head!=meet){head=head->next;meet=meet->next;}   return meet;}}return NULL;
}

好了,那么本篇博客就到此结束了,如果你觉得本篇博客对你有些帮助,可以给个大大的赞👍吗,感谢看到这里,我们下篇博客见❤️

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

相关文章:

  • SparkStreaming在实时处理的两个场景示例
  • 02点亮一个LED
  • 【代码分享】
  • windows 使用ffmpeg .a静态库:读取Wav音频并保存PCM
  • Docker部署ZooKeeper
  • 在PyCharm中使用Git
  • 【JavaSE】 P165 ~ P194 抽象方法,抽象类,接口,接口内容,多接口实现和父类继承,多态,向上转型,向下转型
  • LeetCode: 数组中的第K个最大元素
  • 亚马逊自养号测评:如何安全搭建环境,有效规避风险
  • uniApp 调整小程序 单个/全部界面横屏展示效果
  • 【java】18:内部类(2)匿名内部类
  • c语言之字符串的输入和输出
  • 戏说c第二十六篇: 测试完备性衡量(代码覆盖率)
  • C语言初阶—函数
  • vue3的router
  • 云时代【5】—— LXC 与 容器
  • npm digital envelope routines::unsupported
  • 深入理解Flutter中的StreamSubscription和StreamController
  • 聊聊 HTTP 性能优化
  • 六、防御保护---防火墙内容安全篇
  • HC32F460 是否有 RTC?在电池供电方案中该如何使用?
  • HTML---表单验证
  • 基于tomcat的JavaWeb实现
  • AI时代编程新宠!如何让孩子成为未来的编程大师?
  • Qt 中Json的构造和解析简单例子
  • CSS特性
  • springcloud:3.1介绍雪崩和Resilience4j
  • 实现定时器的两种方法:使用windows api定时器 和使用c++11/14 定时器
  • H5:图像标签和路径
  • AI学习(5):PyTorch-核心模块(Autograd):自动求导