作者:月亮嚼成星~
博客主页:月亮嚼成星~的博客主页
专栏:每日一道LeetCode
工欲善其事必先利其器,给大家介绍一款超牛的斩获大厂offer利器——牛客网
目录
数组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
-
- 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
1;i++){ - ret+=i;
- }
-
- for(int i=0;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
- 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
- int temp=nums[left];
- nums[left]=nums[right];
- nums[right]=temp;
- left++;
- right--;
- }
-
- }
- }
空间复杂度为 O(1)
-
相关阅读:
android 锁屏通知
Kubernetes学习(一)安装minikube
将 EMQX Cloud 数据通过公网桥接到 AWS IoT
【Vue 开发实战】基础篇 # 4:Vue组件的核心概念:插槽
数论合集
如何使用Vuex来管理应用程序的状态?
all in one 部署
TP、TN、FP、FN白话解析,看这一篇就够了
导航【C++】
【闲聊杂谈】源码追踪Spring的三级缓存及循环依赖
-
原文地址:https://blog.csdn.net/m0_67995737/article/details/126745617