Leetcode——287. 寻找重复数

首先很简单的做法即用哈希表记录数字出现的次数,最后循环哈希表输出value值不为1的key值。

cpp 复制代码
class Solution {
public:
    int findDuplicate(vector<int>& nums) {
        unordered_map<int, int> map;
        for(int x : nums){
            map[x]++;
        }
        for(auto& entry : map){
            if(entry.second != 1){
                return entry.first;
            }
        }
        return 0;
    }
};

接着就是考虑高效算法,这里可以将数组看作一个链表,这个思想确实很巧妙,但也很难考虑到。

当看作是一个链表时,其任务就是找链表的环了。

如果允许修改原数组,即我们可以标记负号表示已经来过。

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

如果不允许修改原数组,则用快慢指针找环即可。

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

注意,双指针解法需要从同一位置出发。

当然,此题也可用二分查找求解。

由于我们要找的数范围为1, n,所以取mid,遍历数组,如果<=mid的数字个数小于count,则说明1, mid范围上有数字少了,所以重复数字在mid, n区间。

cpp 复制代码
class Solution {
public:
    int findDuplicate(vector<int>& nums) {
        int len = nums.size();
        int left = 0, right = len - 1;
        while(left < right){
            int mid = left + ((right - left) >> 1);
            int count = 0;
            for(int x : nums){
                if(x <= mid){
                    count++;
                }
            }
            if(count > mid){
                right = mid;
            }else{
                left = mid + 1;
            }
        }
        return left;
    }
};
相关推荐
chase_my_dream6 分钟前
C++ + SLAM 高频面试问题整理
开发语言·c++·面试
牛油果子哥q28 分钟前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++
凡人叶枫2 小时前
Effective C++ 条款04:确定对象被使用前已先被初始化
java·linux·开发语言·c++·嵌入式开发
不想写代码的星星3 小时前
std::move 根本不移动,就像老婆饼里没有老婆
c++
redaijufeng3 小时前
C++雾中风景7:闭包
c++·算法·风景
小欣加油3 小时前
leetcode287寻找重复数
数据结构·c++·算法·leetcode
思麟呀3 小时前
C++11 核心特性(三):强类型枚举、static_assert 与 std::tuple
开发语言·c++
一拳一个呆瓜4 小时前
【STL】C++程序的启动与终止
c++·stl
凡人叶枫4 小时前
Effective C++ 条款07:为多态基类声明 virtual 析构函数
linux·c语言·开发语言·c++
凡人叶枫4 小时前
Effective C++ 条款10:令 operator= 返回一个 reference to *this
java·linux·服务器·开发语言·c++·effective c++