【LeetCode每日一题】——141.环形链表

news2024/12/29 10:10:22

文章目录

  • 一【题目类别】
  • 二【题目难度】
  • 三【题目编号】
  • 四【题目描述】
  • 五【题目示例】
  • 六【解题思路】
  • 七【题目提示】
  • 八【题目进阶】
  • 九【时间频度】
  • 十【代码实现】
  • 十一【提交结果】

一【题目类别】

  • 链表

二【题目难度】

  • 简单

三【题目编号】

  • 141.环形链表

四【题目描述】

  • 给你一个链表的头节点 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
    • 解释:链表中没有环。

六【解题思路】

  • 经典的快慢指针的问题
  • 慢指针走一步,快指针走两步
  • 如果由环,那么快指针和慢指针都会在这个环内“跑”,但是快指针走的快,所以说如果有环,快慢指针一定会相遇
  • 如果快慢指针相遇说明有环,否则说明没环
  • 如果有环返回true,否则返回false即可

七【题目提示】

  • 链 表 中 节 点 的 数 目 范 围 是 [ 0 , 1 0 4 ] 链表中节点的数目范围是 [0, 10^4] [0,104]
  • − 1 0 5 < = N o d e . v a l < = 1 0 5 -10^5 <= Node.val <= 10^5 105<=Node.val<=105
  • p o s 为 − 1 或 者 链 表 中 的 一 个 有 效 索 引 。 pos 为 -1 或者链表中的一个 有效索引 。 pos1

八【题目进阶】

  • 你能用 O ( 1 ) O(1) O(1)(即,常量)内存解决此问题吗?

九【时间频度】

  • 时间复杂度: O ( n ) O(n) O(n),其中 n n n为链表的长度
  • 空间复杂度: O ( 1 ) O(1) O(1)

十【代码实现】

  1. Java语言版
package LinkedList;

/**
 * @Author: IronmanJay
 * @Description: 141.环形链表
 * @CreateTime: 2022-12-05  15:39
 */
public class p141_LinkedListCycle {

    int val;
    p141_LinkedListCycle next;

    public p141_LinkedListCycle(int val) {
        this.val = val;
    }

    public p141_LinkedListCycle(int val, p141_LinkedListCycle next) {
        this.val = val;
        this.next = next;
    }

    public static void main(String[] args) {
        p141_LinkedListCycle node1 = new p141_LinkedListCycle(3);
        p141_LinkedListCycle node2 = new p141_LinkedListCycle(2);
        p141_LinkedListCycle node3 = new p141_LinkedListCycle(0);
        p141_LinkedListCycle node4 = new p141_LinkedListCycle(-4);
        node1.next = node2;
        node2.next = node3;
        node3.next = node4;
        node4.next = node2;
        boolean res = hasCycle(node1);
        System.out.println("res = " + res);
    }

    public static boolean hasCycle(p141_LinkedListCycle head) {
        p141_LinkedListCycle slow = head;
        p141_LinkedListCycle fast = head;
        while (fast != null && fast.next != null) {
            slow = slow.next;
            fast = fast.next.next;
            if (slow == fast) {
                return true;
            }
        }
        return false;
    }

}
  1. C语言版
#include<stdio.h>
#include<stdbool.h>

struct ListNode {
	int val;
	struct ListNode *next;
};

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

/*主函数省略*/

十一【提交结果】

  1. Java语言版
    在这里插入图片描述

  2. C语言版
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/63737.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【gbase8a】docker搭建gbase8a,详细【图文】

docker搭建gbase8a安装docker安装GBase 8a查询安装的版本拉取镜像启动进入容器创建用户dbever测试安装docker 其中具有docker的搭建 搭建docker&#xff0c;docker搭建达梦数据库&#xff0c;详细【图文】 https://blog.csdn.net/weixin_44385419/article/details/127738868 d…

Spark 数据倾斜调优10策

一、数据倾斜概述 1.1 什么是数据倾斜 对Hadoop、Spark、Flink这样的大数据系统来讲&#xff0c;数据量大并不可怕&#xff0c;可怕的是数据倾斜。 何谓数据倾斜&#xff1f;数据倾斜指的是&#xff0c;并行处理的数据集中&#xff0c;某一部分&#xff08;如Spark或Kafka的…

@SpringBootApplication中的注解

Target(ElementType.TYPE)&#xff1a;指示适用注释类型的上下文&#xff08;即注解的作用目标&#xff09;这里是接口、类、枚举、注解 Retention(RetentionPolicy.RUNTIME)&#xff1a;指示具有注释类型的注释要保留多长时间&#xff0c;这里注解是将被JVM保 留,所以在运行…

无法安装64位版本的office,因为在您的PC上找到以下32位程序

无法安装64位版本的office,因为在您的PC上找到以下32位程序: 请卸载所有32位office程序&#xff0c;然后重试安装64位office。如果想要安装32位office&#xff0c;请运行32位安装程序。 那为什么会出现这种情况呢&#xff1f; 首先&#xff0c;我们要知道我们的电脑是32位的还…

9个发展您的B2B业务的LinkedIn营销策略

没有比在 LinkedIn 上与其他公司建立联系更好的地方了。您可以与数以百万计的品牌和专业人士建立联系并发展您的业务。 您可以尝试多种不同的 B2B LinkedIn营销策略&#xff0c;以便与您的受众建立联系并将他们转变为您的客户。 事实上&#xff0c;根据公司自己的研究&#x…

Vue3.2中的setup语法糖(易懂)

简介 在vue3中删除了vue2中的data函数&#xff0c;因此&#xff0c;vue3.0要在template中使用某些变量就必须在最后return出来&#xff0c;多次声明变量&#xff0c;不太方便。而在vue3.2版本之后&#xff0c;新增了setup语法糖。 直接在script标签中添加setup属性就可以直接使…

Arduino开发实例-DIY电能表

DIY电能表 在本文中,将展示如何制作一个基于 Arduino 的功率和电能表。应用使用 INA219 电流传感器测量电流、功率和能耗,并将其显示在 OLED 显示屏上。 可以在 OLED 显示屏上查看您的电压、电流、功率和能量数据。 1、INA219介绍 INA219 电流传感器是一款支持 I2C 的基于…

Unity手机游戏发热发烫优化指南与技巧

Unity手机游戏发热发烫优化指南与技巧 很多小伙伴做完游戏后&#xff0c;发布到Android,运行&#xff0c;游戏很流畅&#xff0c;也不卡顿&#xff0c;但是跑一会游戏,手机就发热,发烫。客户提出需求&#xff0c;能否让它不发烫? 本文从以下3方面来分析手机发烫的问题&#x…

如何用一颗芯片实现5V转正负12V

有时在一些运算放大电路中我们需要同时有正电源和负电源&#xff0c; 但是我们输入一般只有一个正电源&#xff0c;比如我们输入的电源是5V&#xff0c;但是需要将5V转换成正负12V 5V转12V的话我们可以用BOOST电路进行升压&#xff0c;电路图如下 而5V转-12V的话一般有负压电荷…

osgEarth示例分析——osgearth_tracks

前言 osgearth_tracks示例&#xff0c;演示了所有图标沿着路径进行移动(路径是不可见的)。 执行效果 执行命令&#xff1a;osgearth_tracksd.exe earth_image\world.earth 右下角的控制面板功能&#xff1a; Declutter 是否开启 【清理器】 功能。 即当两个图标靠近时&…

HTML期末学生大作业-使用HTML+CSS技术仿传智博客网站

&#x1f389;精彩专栏推荐 &#x1f4ad;文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业&#xff1a; 【&#x1f4da;毕设项目精品实战案例 (10…

今日财富杂志今日财富杂志社今日财富编辑部2022年第21期目录

经济纵横 资产证券化税收政策的国际比较与启示 李依莎; 1-3 中小企业知识产权保护的困境 程诗鸿; 4-6 县级政府在优化营商环境中的作用 李晓春; 7-9《今日财富》投稿&#xff1a;cnqikantg126.com 地域文化背景下论房地产经济发展的区域差异 周莹; 10-12 国…

这把联网智能门锁体验感A+

如果来一次古人与今人的谈话&#xff0c;那一定离不开的话题就是“智能设备”。智能手机、智能电脑、智能手表更新换代如此之快&#xff0c;联网智能门锁亦是如此。对于用户而言&#xff0c;使用智能设备最重要的就是“体验感”了&#xff0c;小编为大家强势推荐中科易安QY-170…

开源多波束前视声呐目标识别数据集

鉴于水下实验的高成本&#xff0c;高专业性&#xff0c;高复杂度的情况&#xff0c;开源水下数据集一直较为稀少。拥有数据的研究机构基本上也只限于自身使用。虎鲸开源计划致力于构建一个开放的实验平台&#xff0c;实验场地、硬件、软件、数据均在开源开放的范畴内。虎鲸开源…

Spring Cloud(十四):微服务灰度发布 --- Discovery

灰度发布微服务全链路灰度全链路灰度设计思路 标签路由节点打标流量染色分布式链路追踪 ThreadLocal流量治理平台 Nacos 配置中心 全链路灰度实现Discovery使用 一、父pom引入Discovery二、Gateway 引入 — 网关 discovery-plugin-strategy-starter-gateway三、微服务 引入 — …

[附源码]JAVA毕业设计论文管理系统(系统+LW)

[附源码]JAVA毕业设计论文管理系统&#xff08;系统LW&#xff09; 环境项配置&#xff1a; Jdk1.8 Tomcat8.5 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a;…

Allegro如何使用快捷键快速切换层面操作指导

Allegro如何使用快捷键快速切换层面操作指导 Allegro可以用快捷键快速切换层面,比如在command下方输入数字1,可以自动打开top层 具体操作如下 打开系统属性,选择环境变量 找到home的环境变量的路径是哪里 找到路径下的pcbenv文件夹 找到env文件 用记事本打开env文件…

自学软件测试,学到什么程度可以出去找工作?

其实初级测试学的东西并不多&#xff0c;如果脱产学习的话2~3个月差不多就能简单入门。 另外不要担心&#xff0c;初级测试对于Python/Java编程&#xff0c;自动化测试&#xff0c;性能测试这些都是初步的了解和学习。如果说要深度掌握&#xff0c;那确实是还需要很多时间。 …

【pen200-lab】10.11.1.10

pen200-lab 学习笔记 【pen200-lab】10.11.1.10 🔥系列专栏:pen200-lab 🎉欢迎关注🔎点赞👍收藏⭐️留言📝 📆首发时间:🌴2022年12月5日🌴 🍭作者水平很有限,如果发现错误,还望告知,感谢! 文章目录 pen200-lab 学习笔记信息收集拓展信息收集 只开放了…

61张图,图解Spring事务,拆解底层源码

下面我会简单介绍一下 Spring 事务的基础知识&#xff0c;以及使用方法&#xff0c;然后直接对源码进行拆解。 不 BB&#xff0c;上文章目录。 ​1. 项目准备 需要搭建环境的同学&#xff0c;代码详见&#xff1a;https://github.com/lml200701158/program_demo/tree/main/spr…