作者:月亮嚼成星~
博客主页:月亮嚼成星~的博客主页
专栏:每日一道LeetCode
工欲善其事必先利其器,给大家介绍一款超牛的斩获大厂offer利器——牛客网
点击免费注册和我一起刷题吧
原题:
面试题 17.04. 消失的数字
数组
nums
包含从
0
到
n
的所有整数,但其中缺了一个。请编写代码找出那个缺失的整数。你有办法在O(n)时间内完成吗?
注意:本题相对书上原题稍作改动
解题思路一:(排序找不同)
数组
nums
包含从
0
到
n
的所有整数,缺失的就在其中,所以我们可以进行排序,使数组的下标与数字对应,所以我们需要找到的是下标和数字不对应的那个,它就是我们要找的缺失的数字。
代码实现:
class Solution {
public int missingNumber(int[] nums) {
Arrays.sort(nums);
int i=0;
for(i=0;i<nums.length;i++){
if(i!=nums[i]){
break;
}
}
return i;
}
}
解题思路二:(数字加减法)
用没有缺失的数组中所有数字之和减去缺失了数字的数组所有的数字之和,它们的差就是该缺失的数字。
代码实现:
class Solution {
public int missingNumber(int[] nums) {
int sum=0;//记录没有缺失的和
int ret=0;//记录缺失的和
for(int i=0;i<nums.length+1;i++){
ret+=i;
}
for(int i=0;i<nums.length;i++){
sum+=nums[i];
}
return ret-sum;
}
}
解题思路三:(异或法)
a ^ a = 0
; 一个数异或自己,结果为零。
a ^ 0 = a
; 一个数异或零,结果为它本身
异或运算满足交换律,结合律 :
a ^ b = b ^ a ; (a ^ b) ^ c = a ^ ( b ^ c ) ;
所以,若 s = a^b^c^d; 如果其中两个数相等,比如 b==c, 则“抵消”,s = a^d。
所以当我们把所有数组下标都异或,并且再异或所有数组中的数字就可以找到缺失的数字,别忘了补上没有缺失的数组的n。
代码实现:
class Solution {
public int missingNumber(int[] nums) {
int ret=0;//用来进行异或运算
//对所有下标和数组中的数字进行异或
for(int i=0;i<nums.length;i++){
ret^=i;
ret^=nums[i];
}
//最后别忘了n下标(补上缺失的数字后的数组下标比缺失的多1)
ret^=nums.length;//n就是nums.length
return ret;
}
}
原题:
- 轮转数组
给你一个数组,将数组中的元素向右轮转
k
- *个位置,其中
k
- *是非负数。
解题思路: (翻转法)
**过程: **
代码实现:
class Solution {
public void rotate(int[] nums, int k) {
k%=nums.length;//防止k超出数组范围
reverse(nums,0,nums.length-1);//整体翻转
reverse(nums,0,k-1);//前部分翻转
reverse(nums,k,nums.length-1);//后部分翻转
}
//自定义翻转方法
public void reverse(int[] nums,int left,int right){
while(left<right){
int temp=nums[left];
nums[left]=nums[right];
nums[right]=temp;
left++;
right--;
}
}
}
** 空间复杂度为
O(1)
**
版权归原作者 月亮嚼成星~ 所有, 如有侵权,请联系我们删除。