【力扣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];
    }
};

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

相关推荐
2501_9272274410 分钟前
密集遮挡场景识别率↑31%!陌讯轻量化部署方案在智慧零售的实战解析
人工智能·算法·目标检测·计算机视觉·目标跟踪·零售
金智维科技官方10 小时前
常见的大模型分类
人工智能·算法·ai·语言模型·数据挖掘
yzzzzzzzzzzzzzzzzz10 小时前
leetcode热题——有效的括号
算法·
崎岖Qiu11 小时前
leetcode1343:大小为K的子数组(定长滑动窗口)
java·算法·leetcode·力扣·滑动窗口
Shun_Tianyou11 小时前
Python Day25 进程与网络编程
开发语言·网络·数据结构·python·算法
Giser探索家12 小时前
什么是2米分辨率卫星影像数据?
大数据·人工智能·数码相机·算法·分类·云计算
jz_ddk14 小时前
[科普] AI加速器架构全景图:从GPU到光计算的算力革命
人工智能·学习·算法·架构
曦月逸霜14 小时前
内部排序算法总结(考研向)
考研·算法·排序算法
仪器科学与传感技术博士14 小时前
Matplotlib库:Python数据可视化的基石,发现它的美
开发语言·人工智能·python·算法·信息可视化·matplotlib·图表可视化
BOB_BOB_BOB_15 小时前
【ee类保研面试】其他类---计算机网络
计算机网络·面试·职场和发展·保研