LeetCode141:环形链表

2023-11-10

给你一个链表的头节点 head ,判断链表中是否有环。

如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。注意:pos 不作为参数进行传递 。仅仅是为了标识链表的实际情况。

如果链表中存在环 ,则返回 true 。 否则,返回 false 。

示例 1:
在这里插入图片描述

输入:head = [3,2,0,-4], pos = 1
输出:true
解释:链表中有一个环,其尾部连接到第二个节点。
示例 2:
在这里插入图片描述

输入:head = [1,2], pos = 0
输出:true
解释:链表中有一个环,其尾部连接到第一个节点。
示例 3:
在这里插入图片描述

输入:head = [1], pos = -1
输出:false
解释:链表中没有环。
提示:

链表中节点的数目范围是 [0, 104]
-105 <= Node.val <= 105
pos 为 -1 或者链表中的一个 有效索引 。
进阶:你能用 O(1)(即,常量)内存解决此问题吗?

Related Topics
哈希表
链表
双指针

  • 定义两个指针,一快一慢。慢指针每次只移动一步,而快指针每次移动两步。初始时,慢指针和快指针都在位置 head。如果存在链表为环形链表,则在移动的过程中,快指针一定会追上慢指针。否则快指针将到达链表尾部,该链表不为环形链表。
/**
 * Definition for singly-linked list.
 * class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) {
 *         val = x;
 *         next = null;
 *     }
 * }
 */
public class Solution {
    public boolean hasCycle(ListNode head) {
        if (head == null) {
            return false;
        }
        ListNode slowPtr = head, fastPtr = head;
        while (fastPtr.next != null && fastPtr.next.next != null) {
            slowPtr = slowPtr.next;
            fastPtr = fastPtr.next.next;
            if (slowPtr == fastPtr) {
                return true;
            }
        }
        return false;
    }
}
  • 复杂度分析
    时间复杂度:O(N),其中 N 是链表中的节点数。
    空间复杂度:O(1)。我们只使用了两个指针的额外空间。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

LeetCode141:环形链表 的相关文章

随机推荐

  • CocosCreator3.8研究笔记(十八)CocosCreator UI组件(二)

    前面的文章已经介绍了Canvas 组件 UITransform 组件 Widget 组件 想了解的朋友 请查看 CocosCreator3 8研究笔记 十七 CocosCreator UI组件 一 今天我们主要介绍CocosCreator
  • OPENCV基础(图像,视频)

    文章目录 1 图像读取 展示 写入 2 视频读取 展示 写入 1 图像读取 展示 写入 使用cv imread 函数读取图像 使用函数cv imshow 在窗口中显示图像 使用函数cv imwrite 保存图像 import numpy a
  • InputStream为什么不能被重复读取?

    最近上传阿里云的时候同一个文件上传两个服务地址 第一个文件读取以后第二个再去读取就拿不到了 代码如下 内网上传OSS获取key值 String ossKey OSSClientUtil getOSSURL endpoint accessKe
  • kali linux 安装搜狗输入法(解决安装后只有搜狗五笔的问题)

    kali 安装搜狗输入法 解决安装后之后只有搜狗五笔的问题 第一步 去搜狗输入法的官方网站下载搜狗输入法 https pinyin sogou com linux 下载后打开文件所在路径 sougoupinyin 2 3 1 0112 am
  • unity读取json文件乱码以及Invalid character 'v' in input string异常解决方案

    先说PC端吧 PC端乱码很容易解决 itemsTable JsonMapper ToObject File ReadAllText Application dataPath Scripts Json itemsTable json Enco
  • Linux 安装软件 常见问题 x86 or x64

    Linux 安装软件 常见问题 x86 or x64 平民资料 x64 是指CPU是64位版本的 x86 是指CPU是32位版本的 如果你的CPU是64位的 可以安装64位的 也可以安装32位的 反过来只能安装32位的 RedHat Lin
  • React 路由基本使用

    代码示例 有Logint和Layout组件 import React from react import BrowserRouter as Router Redirect Route Switch from react router dom
  • python重命名文件excel,在excel电子表格的文件夹python上重命名多个文件

    I am pretty new at Python and I want to automate a process that takes a lot of my time but now I need to rename about 20
  • js 如何判断属性,包括多级对象的状况

    js目前没有一个明确的方法去判断对象是否存在 尤其是出现多级属性 对象 的情况 一旦一个不存在的属性跨级取 就会报错 undefined 因此考虑封装一个通用的方法去专门检测 如果存在属性返回true 反之返回falsefunction c
  • # HTB-Tier2- Oopsie

    HTB Tier2 Oopsie Tags PHP Web Custom Applications Session Handling Apache Penetration Tester Level 1 Reconaisance Web Si
  • 在 uni-app 中选中奇偶子元素

    问题描述 在 uni app 中 使用 nth child 选择器选择奇偶子元素不像预期那样生效 原代码 nth child 2n 选择偶数个子元素 nth child 2n 1 选择奇数个子元素 奇数子元素 issueData item
  • redux的理解及其工作原理?工作流程?

    理解 redux是一个用于管理JavaScript应用程序状态的可预测状态容器 它是一个独立于任何特定UI库的状态管理库 但在React应用中广泛使用 工作原理可以概括为一下几个关键概念 1 store 存储 redux应用的状态 Stat
  • 调试笔记之雨过天晴多点还原软件MBR实例

    BY SUDAMI 为了能够调试多点还原软件 雨过天晴 的启动代码 目前有2种方式 引用 1 在Bochs调试器上装Windows XP系统 然后用Bochs单步调试 不过光安装操作系统就得花20个小时以上 2 用Wnhex克隆整个磁盘 配
  • 求点集中存在的点,满足:其x、y坐标值不同时小于点集中任意一点的x、y坐标值

    问题描述 对于平面上的两个点p1 x1 y1 和p2 x2 y2 如果x1 lt x2且y1 lt y2 则p2支配p1 给定平面上的n个点 请设计算法求其中没有被任何其他点支配的点 换句话说 即 求点集中存在的点 满足 其x y坐标值不同
  • Java实现杨辉三角

    杨辉三角的模型 分析 1 最外层的数字始终是 1 2 每个数等于它上方两数之和 public class Yanghui public static void main String args int yanghui new int 10
  • springcloud配合eureka遇到的巨坑

    springcloud配合eureka遇到一个巨坑 这个问题困扰了楼主整整3天 问题描述 项目在idea能够启动 注册服务 心跳检测一切正常 但是打包后放入服务器中 发现项目启动正常 服务注册正常 但是过了30秒后 eureka开始报错 报
  • [JSP暑假实训] 五.MyEclipse+Servlet+JSP实现火车票网站注册操作及登陆验证

    本系列文章是作者暑假给学生进行实训分享的笔记 主要介绍MyEclipse环境下JSP网站开发 包括JAVA基础 网页布局 数据库基础 Servlet 前端后台数据库交互 DAO等知识 前一篇文章讲解了MyEclipse Servlet JS
  • 用户管理相关命令

    用户管理相关命令 实验目的 通过对用户管理相关命令进行练习 能够对linux中用户和组的维护和管理工作熟练处理 实验内容 1 su命令 切换另一用户 切换主用户时需要输入密码 2 用户相关命令 useradd 创建新用户 passwd us
  • android 检查otg,怎么查看手机是否支持otg

    怎么查看手机是否支持otg很多同学都遇到了这个问题 那么该如何解决呢 请看IEfans小编给大家带来的查看手机是否支持otg方法一览 希望对您有所帮助 工具 原料 手机 VIVO X6S A 系统 PD1415BA A 3 13 10And
  • LeetCode141:环形链表

    给你一个链表的头节点 head 判断链表中是否有环 如果链表中有某个节点 可以通过连续跟踪 next 指针再次到达 则链表中存在环 为了表示给定链表中的环 评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置 索引从 0 开始 注意