作者:月亮嚼成星~
博客主页:月亮嚼成星~的博客主页
专栏:每日一道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)
-
相关阅读:
ftp传送文件脚本
在 Navicat 中执行数据库范围搜索
使用 prometheus 监控主机
蓝桥杯每日一题2023.10.16
MongoDB搭建及基础操作
MATLAB算法实战应用案例精讲-【图像处理】SLAM技术详解
[已解决]windows下如何离线安装python第三方包呢?
how install java on windows
java基础11
U盘无法正常格式化?教你一个强力的办法
-
原文地址:https://blog.csdn.net/m0_67995737/article/details/126745617