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

<!-- more -->

博客阐明

文章所波及的材料来自互联网整顿和集体总结,意在于集体学习和教训汇总,如有什么中央侵权,请分割自己删除,谢谢!

阐明

剑指offer,53-II

0~n-1中缺失的数字

题目

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

示例 1

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

示例 2

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

Java

思路

判断下标是否为以后的数,不是间接返回

代码
class Solution {    public int missingNumber(int[] nums) {        for(int i = 0;i<nums.length;i++){            if(nums[i] != i){                return i;            }        }           return nums.length;    }}
思路

应用二分法

代码
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

以及勤奋的本人