# 剑指 Offer 53 - II. 0~n-1中缺失的数字
一个长度为
n-1
的递增排序数组中的所有数字都是唯一的,并且每个数字都在范围0~n-1
之内。在范围0~n-1
内的n
个数字中有且只有一个数字不在该数组中,请找出这个数字。
输入: [0,1,3]
输出: 2
输入: [0,1,2,3,4,5,6,7,9]
输出: 8
1
2
3
4
5
2
3
4
5
# 解答
利用数组的中间元素
mid
进行二分法判断,如果mid
和nums[mid]
是相等的,说明mid
左边区域的连贯的,缺失的元素在右边区域。
var missingNumber = function(nums) {
let low = 0, high = nums.length-1
while(low<=high) {
let mid=(low+high) >>> 1
if(mid === nums[mid]) {
low = mid+1
} else {
high = mid-1
}
}
return low
};
1
2
3
4
5
6
7
8
9
10
11
12
2
3
4
5
6
7
8
9
10
11
12