前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >287. 寻找重复数

287. 寻找重复数

作者头像
名字是乱打的
发布2021-12-24 08:32:49
4080
发布2021-12-24 08:32:49
举报
文章被收录于专栏:软件工程

一. 题目:

二. 思路:

确定映射关系:数组下标 -> 数组值 有重复元素就意味着必然有两条不同起点的边映射到一个值上,即指向同一个点,因此就会产生环 [1,2,4,5,6,4,3]

index -> value

映射关系

形成了0->1->2->4->6->3->5->4->6->3的环形表

至此,问题转换为 142 题 环形链表。那么针对此题,快、慢指针该如何走呢。根据上述数组转链表的映射关系,可推出 142 题中慢指针走一步 slow = slow.next ==> 本题 slow = nums[slow] 142 题中快指针走两步 fast = fast.next.next ==> 本题 fast = nums[nums[fast]]

三. 代码:

代码语言:javascript
复制
class Solution {
    public int findDuplicate(int[] nums) {
        //快慢指针索引位置
        int slow=nums[0], fast=nums[nums[0]];

        //找到相遇结点
        while (nums[slow]!=nums[fast]){
            slow=nums[slow];
            fast=nums[nums[fast]];
        }


        //找到起始结点
        fast=0;
        while (slow!=fast){
            slow=nums[slow];
            fast=nums[fast];
        }

        return slow;
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/11/16 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一. 题目:
  • 二. 思路:
  • 三. 代码:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档