码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【LeetCode力扣】287.寻找重复数(中等)


    1、题目介绍

    原题链接:287. 寻找重复数 - 力扣(LeetCode)

    示例 1:

    输入:nums = [1,3,4,2,2]
    输出:2
    

    示例 2:

    输入:nums = [3,1,3,4,2]
    输出:3
    

    提示:

    • 1 <= n <= 105
    • nums.length == n + 1
    • 1 <= nums[i] <= n
    • nums 中 只有一个整数 出现 两次或多次 ,其余整数均只出现 一次

    2、解题

    2.1、解题思路

    当我们用一个指针 i=0 以 i = nums[i]; 的方式遍历数组nums[ ]后可以得到图1,因为数组nums[ ]中一定存在的重复的数字 target,所以 target=( 6 ) 这个位置一定有起码两条指向它的边,因此整张图一定存在环,且我们要找到的 target就是这个环的入口,同时也是这道题的答案。用这种方法需要对「Floyd 判圈算法」有所了解。

    「Floyd 判圈算法」(又称龟兔赛跑算法),可用于判定链表、迭代函数、有限状态机中是否有环。如果有环,可以找出环的起点,求出环的长度。 

    基本思想:利用了快慢指针的思想。比如两个人在赛跑,A速度快,B速度慢,若是存在环(勺状图),A和B总是会相遇的,相遇时A所经过的路径的长度要比B多若干个环的长度。

    • 算法时间复杂度:令S到P的距离为m,环的长度为n,时间复杂度O(m+n),即O(n);
    • 空间复杂度:O(1);

    图1: 

    ​ 

    2.2、图解说明

    定义两个指针,分别是慢指针slow和快指针fast。

    一开始让两个指针都指向下标0,然后两个指针每次指向的下一个下标为数组里当前下标的值,slow指针每次进行一次指向下一个下标的操作,fast指针每次进行两次指向下一个下标的操作;

    即:slow = nums[ slow ] ;   fast = nums[ nums[ fast ] ] ;

    然后判断slow 是否等于fast,即:while(slow != fast)

    根据「Floyd 判圈算法」,两个指针在有环的情况下一定会相遇,所以当两个指针在环里面相遇的时候我们再将 slow指针 放置起点 0,两个指针每次同时移动一步,相遇的点就是答案(即环的入口)。

     ​​​​

    ​

    ​

    ​

    这时候让slow等于4,fast等于4然后fast再等于6,即:slow = nums[ slow ] ;   fast = nums[ nums[ fast ] ] ; 所以slow = 4 不等于fast = 6

    ​

    ​

    ​

    这时候让slow等于6,fast等于3然后fast再等于6,即:slow = nums[ slow ] ;   fast = nums[ nums[ fast ] ] ; 所以slow = 6 等于fast = 6

    这时候我们将 slow指针放置起点 0,两个指针每次同时移动一步

    ​

    ​

    ​

    ​

    ​

    这时候slow=fast等于6 ,所以返回答案6

    2.3、解题代码

    1. class Solution {
    2. public int findDuplicate(int[] nums) {
    3. int slow = 0, fast = 0;
    4. do{
    5. slow = nums[slow];
    6. fast = nums[nums[fast]];
    7. } while(slow != fast);
    8. slow = 0;
    9. while(slow != fast){
    10. slow = nums[slow];
    11. fast = nums[fast];
    12. }
    13. return slow;
    14. }
    15. }

    ​

    时间复杂度:O(n)O(n)O(n)。「Floyd 判圈算法」时间复杂度为线性的时间复杂度。

    空间复杂度:O(1)O(1)O(1)。我们只需要常数空间存放若干变量。

     【LeetCode力扣】相关:

    【LeetCode力扣】11. 盛最多水的容器 (中等)-CSDN博客icon-default.png?t=N7T8https://blog.csdn.net/m0_65277261/article/details/134102596?spm=1001.2014.3001.5502【LeetCode力扣】70. 爬楼梯 (简单)-CSDN博客icon-default.png?t=N7T8https://blog.csdn.net/m0_65277261/article/details/134033485?spm=1001.2014.3001.5502【LeetCode力扣】86.分隔链表-CSDN博客icon-default.png?t=N7T8https://blog.csdn.net/m0_65277261/article/details/133972240?spm=1001.2014.3001.5502

    ​

  • 相关阅读:
    设计模式之观察者模式
    【7.21-26】代码源 - 【平方计数】【字典序最小】【“Z”型矩阵】
    Vue组件template标签波浪线报错
    工业和信息化部公布45个国家先进制造业集群名单
    联邦学习综述三
    【微服务架构组件之配置中心一】Nacos
    宇视高空抛物相机配置指导
    cad怎么转为黑白pdf
    神经网络 深度神经网络,主流的神经网络的框架
    ArcGIS笔记12_ArcGIS搜索工具没法用?ArcGIS运行很慢很卡?
  • 原文地址:https://blog.csdn.net/m0_65277261/article/details/134232926
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号