【Golang】LeetCode 287. 寻找重复数

287. 寻找重复数

我发现每当我隔一段时间不刷题,都会重新开始一次 Hot 100。但每一次刷完前 60 ~ 70 题就又懈怠了,导致前面大部分题目我已经刷过很多次,而后面的题目只刷过一次(幸存者偏差)。所以这一次重新开始刷题,我准备从后往前刷。

LeetCode 第 287 题是 Hot 100 的最后一道题,也就是「寻找重复数」。

题目描述

思路

题目中已经明确提到,这个数组包含n+1个整数,并且每个数的范围都在[1, n]内,并且明确提到至少存在一个重复的整数。因此,我们可以使用「Floyd 判圈算法」来解决这道题。

Hot 100 当中的链表部分有两道题,分别是「环形链表」和「环形链表 II」,这道题实际上就是「判断环形链表入口」的应用。

具体来说,我们可以将输入数组nums看作是一个链表,数组当中的每一个下标位置就是链表的节点,而下标对应的值就是链表中下一个节点的索引(Next)。我们首先设置slow := nums[0]以及fast := nums[0],然后通过快慢指针的思路找到slow == fast的位置。再然后,我们使用「环形链表 II」当中 Floyd 判圈算法的思路,令slow = nums[0],然后slowfast指针同时在链表当中向后移动,直到二者相等,这个位置就是环形链表的入口,也就是重复数。

从图示当中不难看出,节点24之间构成了环,最终找到环的入口,就是2,也就是那个重复的数字。

Golang 题解

go 复制代码
func findDuplicate(nums []int) int {
    slow := nums[0]
    fast := nums[0]

    for {
        slow = nums[slow]
        fast = nums[nums[fast]]

        if slow == fast {
            break
        }
    }

    slow = nums[0]
    for slow != fast {
        slow = nums[slow]
        fast = nums[fast]
    }

    return slow
}
相关推荐
被摘下的星星4 分钟前
Java的类加载
java·开发语言
skilllite作者8 分钟前
SkillLite 多入口架构实战:CLI / Python SDK / MCP / Desktop / Swarm 一页理清
开发语言·人工智能·python·安全·架构·rust·agentskills
秋月的私语13 分钟前
遥感影像拼接线优化工具:基于Qt+GDAL+OpenCV的从零到一实践
开发语言·qt·opencv
xwz小王子22 分钟前
智元发布 GO-2:动作空间推理 + 全生命周期闭环,让机器人稳定可靠落地
开发语言·golang·机器人
charlie11451419122 分钟前
通用GUI编程技术——图形渲染实战(二十八)——图像格式与编解码:PNG/JPEG全掌握
开发语言·c++·windows·学习·图形渲染·win32
GDAL22 分钟前
Go Channel `make()` 深入全面讲解
golang·make·通道
ZC跨境爬虫25 分钟前
海南大学交友平台登录页开发实战day4(解决python传输并读取登录信息的问题)
开发语言·前端·python·flask·html
wjs202427 分钟前
SQL LEN() 函数详解
开发语言
姓刘的哦33 分钟前
Qt自定义控件
开发语言·qt
Ricky_Theseus33 分钟前
C++静态库
开发语言·c++