算法创作 | 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

运行代码

 


结语

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

目录
相关文章
|
12月前
|
存储 算法 程序员
【五一创作】C++程序设计与算法(一) 北京大学 郭炜(下)
【五一创作】C++程序设计与算法(一) 北京大学 郭炜(下)
51 0
|
12月前
|
算法 Java C语言
【五一创作】C++程序设计与算法(一) 北京大学 郭炜(上)
【五一创作】C++程序设计与算法(一) 北京大学 郭炜
80 0
|
4月前
|
算法 C语言
C语言----判断n是否是2的次方数,利用到按位与&,算法n&(n-1)
C语言----判断n是否是2的次方数,利用到按位与&,算法n&(n-1)
|
4月前
|
算法 Java
Java数据结构与算法:冲突解决方法
Java数据结构与算法:冲突解决方法
|
算法 Python
算法创作|规则数列计算解决方法
算法创作|规则数列计算解决方法
67 2
|
算法
算法创作|神奇语言问题解决方法
算法创作|神奇语言问题解决方法
65 1
|
算法 C语言
C语言:使用 普通方法 和 二分查找算法(折半查找算法) 在一个有序数组中查找具体的某个数字n-1
思路一:普通方法 (逻辑简单,在无序数组中也可以使用,但效率较低,需要逐个查找) 总体思路:
|
4天前
|
传感器 算法 C语言
基于无线传感器网络的节点分簇算法matlab仿真
该程序对传感器网络进行分簇,考虑节点能量状态、拓扑位置及孤立节点等因素。相较于LEACH算法,本程序评估网络持续时间、节点死亡趋势及能量消耗。使用MATLAB 2022a版本运行,展示了节点能量管理优化及网络生命周期延长的效果。通过簇头管理和数据融合,实现了能量高效和网络可扩展性。
|
1月前
|
算法 BI Serverless
基于鱼群算法的散热片形状优化matlab仿真
本研究利用浴盆曲线模拟空隙外形,并通过鱼群算法(FSA)优化浴盆曲线参数,以获得最佳孔隙度值及对应的R值。FSA通过模拟鱼群的聚群、避障和觅食行为,实现高效全局搜索。具体步骤包括初始化鱼群、计算适应度值、更新位置及判断终止条件。最终确定散热片的最佳形状参数。仿真结果显示该方法能显著提高优化效率。相关代码使用MATLAB 2022a实现。
|
1月前
|
算法 数据可视化
基于SSA奇异谱分析算法的时间序列趋势线提取matlab仿真
奇异谱分析(SSA)是一种基于奇异值分解(SVD)和轨迹矩阵的非线性、非参数时间序列分析方法,适用于提取趋势、周期性和噪声成分。本项目使用MATLAB 2022a版本实现从强干扰序列中提取趋势线,并通过可视化展示了原时间序列与提取的趋势分量。代码实现了滑动窗口下的奇异值分解和分组重构,适用于非线性和非平稳时间序列分析。此方法在气候变化、金融市场和生物医学信号处理等领域有广泛应用。
下一篇
无影云桌面