算法创作 | 0到n-1中缺失的数字问题解决方法

简介: 算法创作 | 0到n-1中缺失的数字问题解决方法

问题描述

一个长度为n-1的递增排序数组中的所有数字都是唯一的,并且每个数字都在范围0n-1之内。在范围0n-1内的n个数字中有且只有一个数字不在该数组中,请找出这个数字。

示例1:

输入:[0,1,3]

输出:2

示例2

输入:[0,1,2,4]

输出:3

解决方案

左边界i=0,右边界j=len(nums)-1;闭区间[i,j]。当ij时开始循环(即当闭区间[i,j]为空时跳出循环;计算中点m=(i+j)//2,其中"//"为向下取整除法;若nums[m]=m,则“右子数组的首位元素”一定在闭区间[m+1,j]中,便执行i=m+1;若nums[m]=m,则左子数组末位元素”一定在闭区间[i,m1]中,因此执行j=m1;跳出时,变量ij分别指“右子数组的首位元素”“左子数组的末位元素”,返回i

代码清单 1 0~n-1中缺失的数的代码清单

class Solution:

    def missingNumber(self, nums: List[int]) -> int:

        i, j = 0, len(nums) - 1

        while i <= j:

            m = (i + j) // 2

            if nums[m] == m: i = m + 1

            else: j = m - 1

        return i

运行代码

 


结语

首先看到此题,想到的第一种方法便是二分法,当然,此题也有一些其他的办法,只是二分法更加常用,更容易想到,可以根据规则将数组划分为左子数组和右子数组两部分,根据缺失的数字为右子数组的首位元素作为对应的索引,便可得到所缺失的数。

目录
相关文章
|
存储 算法 程序员
【五一创作】C++程序设计与算法(一) 北京大学 郭炜(下)
【五一创作】C++程序设计与算法(一) 北京大学 郭炜(下)
56 0
|
算法 Java C语言
【五一创作】C++程序设计与算法(一) 北京大学 郭炜(上)
【五一创作】C++程序设计与算法(一) 北京大学 郭炜
95 0
|
5月前
|
算法 C语言
C语言----判断n是否是2的次方数,利用到按位与&,算法n&(n-1)
C语言----判断n是否是2的次方数,利用到按位与&,算法n&(n-1)
|
5月前
|
算法 Java
Java数据结构与算法:冲突解决方法
Java数据结构与算法:冲突解决方法
|
算法 Python
算法创作|规则数列计算解决方法
算法创作|规则数列计算解决方法
72 2
|
算法
算法创作|神奇语言问题解决方法
算法创作|神奇语言问题解决方法
68 1
|
算法 C语言
C语言:使用 普通方法 和 二分查找算法(折半查找算法) 在一个有序数组中查找具体的某个数字n-1
思路一:普通方法 (逻辑简单,在无序数组中也可以使用,但效率较低,需要逐个查找) 总体思路:
100 0
|
24天前
|
算法 安全 数据安全/隐私保护
基于game-based算法的动态频谱访问matlab仿真
本算法展示了在认知无线电网络中,通过游戏理论优化动态频谱访问,提高频谱利用率和物理层安全性。程序运行效果包括负载因子、传输功率、信噪比对用户效用和保密率的影响分析。软件版本:Matlab 2022a。完整代码包含详细中文注释和操作视频。
|
9天前
|
算法 数据挖掘 数据安全/隐私保护
基于FCM模糊聚类算法的图像分割matlab仿真
本项目展示了基于模糊C均值(FCM)算法的图像分割技术。算法运行效果良好,无水印。使用MATLAB 2022a开发,提供完整代码及中文注释,附带操作步骤视频。FCM算法通过隶属度矩阵和聚类中心矩阵实现图像分割,适用于灰度和彩色图像,广泛应用于医学影像、遥感图像等领域。
|
11天前
|
算法 调度
基于遗传模拟退火混合优化算法的车间作业最优调度matlab仿真,输出甘特图
车间作业调度问题(JSSP)通过遗传算法(GA)和模拟退火算法(SA)优化多个作业在并行工作中心上的加工顺序和时间,以最小化总完成时间和机器闲置时间。MATLAB2022a版本运行测试,展示了有效性和可行性。核心程序采用作业列表表示法,结合遗传操作和模拟退火过程,提高算法性能。