287. 寻找重复数 Python

文章目录


一、题目描述

给定一个包含 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

二、代码

代码如下:

c 复制代码
class Solution:
    def findDuplicate(self, nums: List[int]) -> int:
        n = len(nums)
        left, right = 0, n
        while left < right:
            k = (left + right) // 2
            count = sum(num <= k for num in nums)   # nums中 <=k 的元素个数
            if count <= k:      # 目标元素在k右侧
                left = k+1
            else:
                right = k
        return right

三、解题思路

本题要求查找数组中重复的那个数,由于题意要求不能修改数组且只能使用常量级 O(1) 的额外空间,所以采用空间换效率的方法不太适合,采用先排序后查找的方法也不满足条件。但是由于本题中题意给出的条件是数组中的每一个元素肯定是属于[1, n] 范围内的(包括 1n)且有且仅有1个数是重复的,那么可以采用二分法的思路去寻找重复的数,具体思路如下:

设一个数字k∈[1, n] ,统计数组中小于等于k的数字的 个数 count

count<=k,说明重复数字一定在(k,n−1]的范围内。

count>k,说明重复数字一定在[0,k]的范围内。

而实际上,k的选取就是二分查找中的中间值。最终如果左坐标left等于右坐标right,说明找到了重复的数,返回left或者right即可。

相关推荐
jay神2 分钟前
基于 YOLOv8 的PCB 缺陷检测系统
python·深度学习·yolo·目标检测·信息可视化·毕业设计
wayz116 分钟前
Day 2:线性回归原理与正则化
算法·机器学习·数据分析·回归·线性回归
zhaoshuzhaoshu14 分钟前
设计模式之行为型设计模式详解
python·设计模式
QQ6765800817 分钟前
基于yolo26算法的水下目标检测图像数据集 海洋生物识别 海胆识别 海龟识别数据集 海洋生物监测与保护工作 潜水作业安全辅助系 水下环境感知第10408期
算法·目标检测·水下目标检测·海洋生物识别·海胆 海龟识别·海洋生物监测与保护工作·潜水作业安全辅助 水下环境感知
七颗糖很甜30 分钟前
基于 OpenCV 的 FY2 云顶图云块追踪算法实现
人工智能·opencv·算法
__Wedream__31 分钟前
NTIRE 2026 Challenge on Efficient Super-Resolution——冠军方案解读
人工智能·深度学习·算法·计算机视觉·超分辨率重建
FL162386312935 分钟前
基于深度学习mediape实现人员跌倒人体姿势跌倒检测算法源码+说明文件
人工智能·深度学习·算法
wangwangmoon_light36 分钟前
1.23 LeetCode总结(树)_一般树
算法·leetcode·职场和发展
不知名XL36 分钟前
day01 agent开发基础铺垫
python