leetcode:环形链表

题目描述

题目链接:141. 环形链表 - 力扣(LeetCode)

题目分析

我们先了解一个知识:循环链表

尾结点不指向NULL,指向头就是循环链表

那么带环链表就意味着尾结点的next可以指向链表的任意一个结点,甚至可以指向他自己

这里我们的算法思路唯一靠谱的还是快慢指针

slow一次走一步,fast一次走两步,当slow走到中间的时候,fast一定入环了,如果fast指向NULL,则该链表无环

当slow再走一半也就入环了,这个时候,由于slow走的慢,fast走的快,所以fast和slow最终会相遇的

那我们的代码就应该是

如果fast或者fast->next为NULL则返回false

当fast或者fast->next不为NULL的时候,slow走一步,fast走两步,当fast==slow,则返回true

代码示例

根据思路我们就可以写代码了:

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

当然结果也通过了

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

指令不明,成员困惑,项目经理如何明确每个人的职责

有一个故事,讲述了一个餐厅客人在点餐时要求吃螃蟹,但是餐厅已经卖完了。幸运的是,楼下的商铺有售卖螃蟹。 经理吩咐小李去询问价格,小李迅速返回并汇报了价格。然而,经理进一步询问了螃蟹的数量,小李才意…

Git远程库操作(GitHub)

GitHub 网址:https://github.com/ 创建远程仓库 远程仓库操作 命令名称作用git remote -v查看当前所有远程地址别名git remote add 别名 远程地址起别名git push 别名 分支推送本地分支上的内容到远程仓库git clone 远程地址将远程仓库的内容克隆到本地git pull 别…

关于CRM系统中的客户,您需要知道这些

今天为大家讲解CRM中客户是什么?如何进行客户管理?CRM系统中有购买意向和已经购买了产品的消费者都属于客户。对于B2B企业,会将企业看作客户,而对于B2C企业来说每一位消费的个体都是客户。 CRM中的客户管理无疑是业务重点&#x…

计算机毕业设计项目选题推荐(免费领源码)java+springboot+mysql社区团购APP 02043

目录 摘要 1 绪论 1.1 研究背景 1.2国内外研究现状 1.3本课题主要工作 1.4论文结构与章节安排 2 社区团购系统分析 2.1 可行性分析 2.2 系统流程分析 2.2.1 数据流程 3.3.2 业务流程 2.3 系统功能分析 2.3.1 功能性分析 2.3.2 非功能性分析 2.4 系统用例分析 2.…

云数据仓库实践:AWS Redshift在大数据储存分析上的落地经验分享

🏆作者简介,黑夜开发者,CSDN领军人物,全栈领域优质创作者✌,CSDN博客专家,阿里云社区专家博主,2023年6月CSDN上海赛道top4。 🏆数年电商行业从业经验,历任核心研发工程师…

超级会员卡积分收银系统源码 会员卡+积分商城+收银功能+多门店系统 附带完整的搭建教程

线上线下的融合已经成为趋势。在这个过程中,会员卡积分收银系统成为了许多企业不可或缺的一部分。该系统以超级会员卡为基础,结合积分商城、收银功能以及多门店系统,为企业提供了一站式的解决方案,帮助企业实现线上线下会员一体化…

Python 第一行代码 —— 打印 hello world

第一个程序 print ("Hello world!")这种程序虽然简单,却有其用途:如果它能够在你的系统上正确地运行,你编写的任何 Python 程序都将如此。 如果没有看到这样的输出,请检查你输入的每个字符。你是不是将 print 的首字母…

sap系统连接其它系统

本文来自博客园,作者:Lovemywx2,转载请注明原文链接:https://www.cnblogs.com/1187163927ch/p/8669859.html JAVA连接ORACLE数据库 1,首先需要在Oracle安装完成之后新建一个用户 --新建用户 create user chenh iden…

C盘变红怎么办?一个快速解决C盘快满的方法

前情提要 通常解决C盘快满的方法是: 找到C盘—右击选择“属性”—选择“详细信息”—卸载不常用的软件或者清除临时文件 缺点:成效甚微 今日重点 1.背景知识:微信是我们日常工作和生活都离不开的工具,我们每天使用微信会产生大量…

Java线程的学习

本来我以为这可能只是Java里的一小块知识点,但当我搜索自己关注的Up主的网课时,觉得还是开一个系列来记录好了。我的记录绝不仅仅是照搬课程中的内容,我会带上自己的理解以及示例代码、并且是按照本人的专业课老师上课的节奏来记录&#xff0…

【开源】基于Vue和SpringBoot的教学过程管理系统

项目编号: S 054 ,文末获取源码。 \color{red}{项目编号:S054,文末获取源码。} 项目编号:S054,文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 教师端2.2 学生端2.3 微信小程序端2…

近期为何事故频发,企业安全生产如何保障?

近期,多地陆续发生了一系列企业安全生产事故,给企业和员工带来了严重的生命和财产损失,引发了社会各界对安全生产问题的广泛关注。安全生产是企业发展的重要保障,然而,企业在追求经济效益的过程中,往往忽视…

单链表OJ题--6.链表分割

6.链表分割 链表分割_牛客题霸_牛客网 (nowcoder.com) /* 解题思路 创建两个链表,分别存放小于x的节点和大于等于x的节点,分别进行尾插 */ class Partition { public:ListNode* partition(ListNode* pHead, int x) {if(pHead NULL)return NULL;struct …

AMESim|Make failed:Unable to create an excutable for the system

最近在AMESIM与MATLAB进行联合仿真的时候遇到如下问题: Make failed:Unable to create an excutable for the system. 看了网上的解决办法如下 配置环境变量重装AMESIM,有顺序要求,首先是VS,然后是AMESIM与MATLAB。在AMESIM安装…

无法创建 8192 MB 的匿名分页文件: 系统资源不足,无法完成请求的服务。

好久没用VMware Workstation,今天突然要用,发现所有的虚机在启动的时候提示都提示: 无法创建 XXXX MB 的匿名分页文件:页面文件太小,无法完成操作。 未能分配主内存。 模块"MainMem"启动失败。 未能启动…

手写promis(2)-- 链式编程篇

目录 链式编程 处理异常 和普通内容 链式编程---处理返回promise 链式编程---处理重复引用 链式编程--rejected 链式编程--处理padding状态 链式编程 处理异常 和普通内容 1.返回promise实例:在原本then方法里边创建新promise2.获取返回值:把原本…

淘宝商品详情页面数据(商品详情数据,商品sku数据,商品价格数据,商品优惠券数据,商品评论数据)接口代码流

淘宝API接口可以运用到多种业务场景中,以下列举了一些主要的场景: 商品信息展示:通过调用淘宝API详情接口,可以获取商品的详细信息,如商品标题、价格、库存、销量、评价等数据。这些信息可以用于在自己的网站或应用程…

WIN10 WIN11 12代 13代 大小核;性能核;电源选项;P-core,E-core;

WIN10 WIN11 12代 13代 大小核;性能核;电源选项;P-core,E-core; WIN10 WIN11 12代 13代 大小核;性能核;电源选项;P-core,E-core;说明:方法:1。右键开始菜单,选择“Window…

arcgis中投影文件(.prj)和地理转换文件(.gtf)存储路径

1、投影文件(自定义的.prj)的存储路径 C:\Users\14635\AppData\Roaming\ESRI\Desktop10.5\ArcMap\Coordinate Systems 2、地理转换文件(.gtf)--自定义 C:\Users\14635\AppData\Roaming\ESRI\Desktop10.5\ArcToolbox\CustomTransfo…