leetcode287寻找重复数

一、问题描述

二、解题思路

解法一:排序+搜索

首先,对nums向量进行一个排序,重复出现的数字会挨在一起,进行搜索即可。

解法二:哈希统计频率

使用哈希表来统计每个数字出现的次数,如果某一数字出现次数超过1次,返回即可。

解法三:快慢双指针

由于本题的数字的范围为0,n,数组的下标为0,n,经过分析可以得知本题实质上是在找环的入口,可以使用快慢双指针来解决:

(1)首先,初始化slow指针为nums0,fast指针为numsnums\[0],slow指针每次走一步,fast指针每次走两步,直至slow==fast;

(2)再定义一个新指针ptr,初始化为nums0,ptr和fast每次走一步,直至二者相遇,返回此时的ptr,即为所求。

三、代码实现

解法一:排序+搜索

cpp 复制代码
class Solution {
public:
    int findDuplicate(vector<int>& nums) {
        //排序+搜索
        sort(nums.begin(),nums.end());
        for(int i=0;i!=nums.size()-1;i++)
            if(nums[i]==nums[i+1]) return nums[i];
        return -1;
    }
};

解法二:哈希统计频率

cpp 复制代码
class Solution {
public:
    int findDuplicate(vector<int>& nums) {
        //哈希表
        unordered_map<int,int> hash;
        for(auto x:nums){
            hash[x]++;
            if(hash[x]>1) return x;
        }
        return -1;
    }
};

解法三:快慢双指针

cpp 复制代码
class Solution {
public:
    int findDuplicate(vector<int>& nums) {
        // 快慢双指针
        int slow = nums[0];
        int fast = nums[nums[0]];
        
        // 第一阶段:找到环中的相遇点
        while (slow != fast) {
            slow = nums[slow];
            fast = nums[nums[fast]];
        }
        
        // 第二阶段:找到环的入口(重复的数字)
        int ptr = 0;
        while (ptr != slow) {
            ptr = nums[ptr];
            slow = nums[slow];
        }
        
        return ptr;
    }
};
相关推荐
思麟呀1 小时前
C++11 核心特性(三):强类型枚举、static_assert 与 std::tuple
开发语言·c++
一拳一个呆瓜1 小时前
【STL】C++程序的启动与终止
c++·stl
尽兴-2 小时前
2.1 向量基础:Embedding、余弦相似度、欧氏距离、向量检索
算法·embedding·欧氏距离·向量检索·余弦相似度
凡人叶枫2 小时前
Effective C++ 条款07:为多态基类声明 virtual 析构函数
linux·c语言·开发语言·c++
Black蜡笔小新2 小时前
自动化AI算法训练服务器DLTM训推一体工作站赋能多行业智能化升级
人工智能·算法·自动化
凡人叶枫2 小时前
Effective C++ 条款10:令 operator= 返回一个 reference to *this
java·linux·服务器·开发语言·c++·effective c++
王老师青少年编程2 小时前
2026年全国青少年信息素养大赛算法应用主题赛(C++赛项-复赛模拟卷6:文末附答案)
c++·答案·模拟卷·复赛·2026年·青少年信息素养大赛·算法应用主题赛
怪兽学LLM2 小时前
LeetCode 438 找到字符串中所有字母异位词(Python 固定滑动窗口+字符计数解法)
python·算法·leetcode
满怀冰雪2 小时前
第04篇-双指针算法-从有序数组到回文判断的高频解法
java·算法