LeetCode 287. 寻找重复数

题目描述

给定一个包含 n + 1 个整数的数组 nums ,其数字都在 [1, n] 范围内(包括 1n),可知至少存在一个重复的整数。

假设 nums 只有 一个重复的整数 ,返回 这个重复的数

你设计的解决方案必须 不修改 数组 nums 且只用常量级 O(1) 的额外空间。

示例

示例 1:

复制代码
输入:nums = [1,3,4,2,2]
输出:2

示例 2:

复制代码
输入:nums = [3,1,3,4,2]
输出:3

示例 3:

复制代码
输入:nums = [3,3,3,3,3]
输出:3

解法

1.二分查找

解题思路

题目给出nums包含 n + 1 个整数,其数字都在 [1, n] 范围内。可以用二分查找法,一步步判断重复数字,是处于[1,mid]和[mid+1,n]两个区间中的哪个区间,每次判断都需要遍历一遍数组,统计在[1,mid]区间中的数字个数cnt,如果cnt大于区间内的元素数量,那么这个重复元素一定在[1,mid]这个区间内,根据二 分法缩小区间;反之亦然,最后min所指的元素,就是重复元素。

虽然nuns不是有序数组,但是我们可以想象一个[1,2,3...n]这样的有序数组,来使用二分查找,而且空间复杂度为O(1)。

cpp 复制代码
class Solution {
public:
    int findDuplicate(vector<int>& nums) {
        int min = 1,max = nums.size();
        while(min < max){
            int mid = (min + max) / 2;
            int cnt = 0;
            for(auto v : nums){
                if(v >= min && v <= mid) cnt ++;
            }
            if(cnt > mid - min + 1){
                max = mid;
            }else{
                min = mid + 1;
            }
        }
        return min;
    }
};

时间复杂度O(NLogN),空间复杂度O(1)

相关推荐
CoovallyAIHub4 小时前
Moonshine:比 Whisper 快 100 倍的端侧语音识别神器,Star 6.6K!
深度学习·算法·计算机视觉
CoovallyAIHub5 小时前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度
深度学习·算法·计算机视觉
CoovallyAIHub5 小时前
实时视觉AI智能体框架来了!Vision Agents 狂揽7K Star,延迟低至30ms,YOLO+Gemini实时联动!
算法·架构·github
CoovallyAIHub6 小时前
开源:YOLO最强对手?D-FINE目标检测与实例分割框架深度解析
人工智能·算法·github
CoovallyAIHub6 小时前
OpenClaw:从“19万星标”到“行业封杀”,这只“赛博龙虾”究竟触动了谁的神经?
算法·架构·github
刀法如飞6 小时前
程序员必须知道的核心算法思想
算法·编程开发·算法思想
徐小夕7 小时前
pxcharts Ultra V2.3更新:多维表一键导出 PDF,渲染兼容性拉满!
vue.js·算法·github
CoovallyAIHub8 小时前
OpenClaw一脚踩碎传统CV?机器终于不再只是看世界
深度学习·算法·计算机视觉
CoovallyAIHub9 小时前
仅凭单目相机实现3D锥桶定位?UNet-RKNet破解自动驾驶锥桶检测难题
深度学习·算法·计算机视觉
zone77399 小时前
002:RAG 入门-LangChain 读取文本
后端·算法·面试