268. Missing Number

Given an array nums containing n distinct numbers in the range [0, n], return the only number in the range that is missing from the array.

Follow up: Could you implement a solution using only O(1) extra space complexity and O(n) runtime complexity?

 

Example 1:

Input: nums = [3,0,1]
Output: 2
Explanation: n = 3 since there are 3 numbers, so all numbers are in the range [0,3]. 2 is the missing number in the range since it does not appear in nums.

Example 2:

Input: nums = [0,1]
Output: 2
Explanation: n = 2 since there are 2 numbers, so all numbers are in the range [0,2]. 2 is the missing number in the range since it does not appear in nums.

Example 3:

Input: nums = [9,6,4,2,3,5,7,0,1]
Output: 8
Explanation: n = 9 since there are 9 numbers, so all numbers are in the range [0,9]. 8 is the missing number in the range since it does not appear in nums.

Example 4:

Input: nums = [0]
Output: 1
Explanation: n = 1 since there is 1 number, so all numbers are in the range [0,1]. 1 is the missing number in the range since it does not appear in nums.

 1 class Solution {
 2     public int missingNumber(int[] nums) { // binary search
 3         Arrays.sort(nums);
 4         int left = 0, right = nums.length - 1;
 5         while (left <= right) {
 6             int mid = (left + right) / 2;
 7             if (nums[mid] > mid)
 8                 right = mid - 1;
 9             else
10                 left = mid + 1;
11         }
12         return left;
13     }
14 }
1 public int missingNumber(int[] nums) { //xor
2     int res = nums.length;
3     for(int i=0; i<nums.length; i++){
4         res ^= i;
5         res ^= nums[i];
6     }
7     return res;
8 }
1 public int missingNumber(int[] nums) { //sum
2     int len = nums.length;
3     int sum = (0+len)*(len+1)/2;
4     for(int i=0; i<len; i++)
5         sum-=nums[i];
6     return sum;
7 }

 

posted @ 2021-03-29 06:09  北叶青藤  阅读(58)  评论(0编辑  收藏  举报