归子莫的博客

「笔杆揭不起,绘不出青烟别春泥 ————归子莫」

LeetCode–0~n-1中缺失的数字

博客说明

文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人删除,谢谢!

说明

剑指offer,53-II

0~n-1中缺失的数字

题目

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

示例 1

1
2
输入: [0,1,3]
输出: 2

示例 2

1
2
输入: [0,1,2,3,4,5,6,7,9]
输出: 8

Java

思路

判断下标是否为当前的数,不是直接返回

代码
1
2
3
4
5
6
7
8
9
10
class Solution {
public int missingNumber(int[] nums) {
for(int i = 0;i<nums.length;i++){
if(nums[i] != i){
return i;
}
}
return nums.length;
}
}
思路

使用二分法

代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
class Solution {
public int missingNumber(int[] nums) {
int i = 0;
int j = nums.length - 1;
while(i <= j){
int m = (i+j)/2;
if(nums[m] == m){
i = m + 1;
}else{
j = m - 1;
}
}
return i;
}
}

感谢

leetcode

以及勤劳的自己

评论