This is the 15th day of my participation in the November Gwen Challenge. Check out the event details: The last Gwen Challenge 2021
Topic describes
Given a containing [0, n] array nums of n numbers, find [0N] the number in the range that does not appear in the array. The sample1: Input: nums = [3.0.1] output:2Explanation: n =3Because there are3Number, so all numbers are in the range [0.3].2Is the missing number because it does not appear in NUMS. The sample2: Input: nums = [0.1] output:2Explanation: n =2Because there are2Number, so all numbers are in the range [0.2].2Is the missing number because it does not appear in NUMS. The sample3: Input: nums = [9.6.4.2.3.5.7.0.1] output:8Explanation: n =9Because there are9Number, so all numbers are in the range [0.9].8Is the missing number because it does not appear in NUMS. The sample4: Input: nums = [0] output:1Explanation: n =1Because there are1Number, so all numbers are in the range [0.1].1Is the missing number because it does not appear in NUMS. N == nums.length1 <= n <= 104
0<= nums[I] <= n All nums numbers are unique//leetcode-cn.com/problems/missing-numberCopyright belongs to the Collar buckle network. Commercial reprint please contact official authorization, non-commercial reprint please indicate the source.Copy the code
Ideas & CODE
They say that the given range is [0,n], which means that there are n+1 numbers in the range, but there are only n numbers in the given array, and the numbers in the array are not duplicated, so the missing number is in the range [0,n]
1. The sum
We just need to sum up all the elements in the array given by the problem, sum up all the elements between [0,n], subtract, and finally get the missing number
public int missingNumber1(int[] nums) {
int sumData = 0;
for (int num : nums) {
sumData += num;
}
return sum(nums.length) - sumData;
}
public int sum(int num) {
if (num == 0) {
return num;
}
return num + sum(num - 1);
}
Copy the code
[0,n] is not an arithmetic sequence, arithmetic sequence summation formula for n(n+1)/2, why silly use recursion…
public int missingNumber(int[] nums) {
int n = nums.length;
int total = n * (n + 1) / 2;
int arrSum = 0;
for (int i = 0; i < n; i++) {
arrSum += nums[i];
}
return total - arrSum;
}
Copy the code
2. Bit operations
Bit operation, saw the comment area immediately remembered a few days ago to do the topic [N6-Q136: only once the number], only a single number, all the other numbers appear in pairs, all for the operation of the result is only once the number.
Here we have two arrays, the array given and the array of all the numbers in [0,n]. Merge the two elements together, and only the missing array appears once!
public int missingNumber2(int[] nums) {
int res = 0;
for (int i = 0; i <= nums.length; i++) {
if (i == nums.length) {
res = res ^ i;
} else{ res = res ^ i ^ nums[i]; }}return res;
}
Copy the code
Although it was done a few days ago, but the first time or could not come up with this solution, do more summary, these commonly used solutions to form muscle memory on the line!
3. The hash
Each item in an array can be hashed…