【力扣hot100题】(099)寻找重复数

我只会用哈希表............

技巧题真的做不了一点............

看了答案也只看懂一个循环,大概是利用查找链表中循环的那个思路。每个节点设置一条i->nums[i]的边,数组中有重复数字就代表必定有环,并且那个重复数字必定在环里面。

几个问题:

①为什么必定有环?

因为有一个数字nums[i]重复,那么这个数字就一定被两个节点指向,而这个i就是那个重复数字。

②怎么查找这个重复的i?

用之前在链表中寻找环入口的方法,双指针,之前证明过了。

cpp 复制代码
class Solution {
public:
    int findDuplicate(vector<int>& nums) {
        int fast=nums[nums[0]];
        int slow=nums[0];
        while(nums[fast]!=nums[slow]){
            fast=nums[nums[fast]];
            slow=nums[slow];
        }
        slow=0;
        while(nums[fast]!=nums[slow]){
            fast=nums[fast];
            slow=nums[slow];
        }
        return nums[fast];
    }
};

总之真的挺奇妙的,居然可以用链表的方法解,明明是看似无关的两题......

相关推荐
·云扬·24 分钟前
【PmHub面试篇】Gateway全局过滤器统计接口调用耗时面试要点解析
面试·职场和发展·gateway
编程绿豆侠2 小时前
力扣HOT100之二分查找: 34. 在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
Shan12053 小时前
找到每一个单词+模拟的思路和算法
数据结构·算法
国家不保护废物3 小时前
微信红包算法深度解析:从产品思维到代码实现
javascript·算法·面试
小明同学013 小时前
[C++入门]简化的艺术---对模版的初步探索
开发语言·c++·算法
kaiaaaa4 小时前
算法训练第八天
算法
LL_xjbt4 小时前
代码随想录刷题day29
算法·leetcode·动态规划
叶子2024224 小时前
守护进程实验——autoDL
人工智能·算法·机器学习
半桔5 小时前
【算法深练】分组循环:“分”出条理,化繁为简
数据结构·c++·算法·leetcode·面试·职场和发展
天天爱吃肉82185 小时前
【十年技术演进深度解构:车载充电机(OBC)将成为新能源汽车的“能源大脑”】
python·嵌入式硬件·算法·汽车·能源