刷题练习笔记

目录

1、消失的数字

2、旋转数组

3、原地移除元素

4、删除排序数组中的重复项


1、消失的数字

oj:面试题 17.04. 消失的数字 - 力扣(LeetCode)

思路(参考评论区):

利用异或的特性,ret = ret ^ x ^ x。级对同一个值异或两次,结果等于它本身

所以对 ret 从 0 - nums.length 进行异或,同时对 nums 数组中的值进行异或,出现重复的会消失,所以最后 ret 的值是只出现一次的数字,也就是nums数组中缺失的那个数字。

java 复制代码
class Solution {
    public int missingNumber(int[] nums) {
        int ret = 0;
        for(int i = 0; i < nums.length; i++) {
            ret ^= i;
            ret ^= nums[i];
        }
        ret ^= nums.length;
        return ret;
    }
}

2、旋转数组

oj:189. 轮转数组 - 力扣(LeetCode)

思路:

  1. 使用额外的数组将每个元素放至旋转后的位置

  2. 遍历原数组,将原数组下标为 i 的元素放至新数组下标为 (i+k)%n 的位置

  3. 再把新数组写回原数组

java 复制代码
class Solution {
    public void rotate(int[] nums, int k) {
        int len = nums.length;
        int[] newArr = new int[len];
        for(int i = 0; i < len; i++){
            newArr[(i+k)%len] = nums[i];
        }
        for(int j = 0; j < len; j++){
            nums[j] = newArr[j];
        }
    }
}

3、原地移除元素

oj:226. 翻转二叉树 - 力扣(LeetCode)

思路:

  1. 遍历数组 nums,设置一个下标 ans
  2. 在遍历过程中如果出现数字不是需要被移除的值,则把这个数字覆盖到ans所在的下标位置,ans 自增 1
  3. 如果相同的时候,则跳过该数字不进行覆盖,最后 ans 即为新的数组长度
java 复制代码
// 时间复杂度:O(n),空间复杂度:O(1)
class Solution {
    public int removeElement(int[] nums, int val) {
        int ans = 0;
        for(int i = 0; i<nums.length; i++) {
            if(nums[i] != val) {
                nums[ans] = nums[i];
                ans++;
            }
        }
        return ans;
    }
}

4、删除排序数组中的重复项

oj:26. 删除有序数组中的重复项 - 力扣(LeetCode)

思路:

  1. 与上题类似,使用两个指针,fast用于遍历数组,slow位置用于存放不重复项

  2. 在遍历过程中如果出现数字不是重复值,则把这个数字覆盖到slow所在的下标位置

  3. slow+1 即为数组中唯一元素的数量

java 复制代码
class Solution {
    public int removeDuplicates(int[] nums) {
        int fast = 1;
        int slow = 0;
        for(; fast<nums.length; fast++) {
            if(nums[fast] != nums[slow]) {
                nums[slow+1] = nums[fast];
                slow++;
            }
        }
        return slow+1;
    }
}
相关推荐
云烟成雨TD1 天前
Spring AI Alibaba 1.x 系列【69】Token 用量统计
java·人工智能·spring
Navigator_Z1 天前
LeetCode //C - 1089. Duplicate Zeros
c语言·算法·leetcode
JAVA9651 天前
JAVA面试-并发篇 03-使用synchronized doublecheck实现单例有什么坑
java·单例模式·面试
在繁华处1 天前
Java从零到熟练(四):面向对象基础
java·开发语言
小江的记录本1 天前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)
java·前端·jvm·后端·python·spring·面试
在繁华处1 天前
Java从零到熟练(三):流程控制
java·开发语言·python
sulikey1 天前
个人Linux操作系统学习笔记6 - 操作系统与进程初识
linux·笔记·学习·操作系统·进程
唐青枫1 天前
Java Optional 实战指南:优雅处理空值与链式转换
java
一起学开源1 天前
一文读懂 ReAct 范式:让 AI Agent 真正学会“思考+行动“
java·javascript·react.js·ecmascript·react·alibaba·智能体开发
云泽8081 天前
C++ 可调用对象通关指南:深度解析 Lambda 表达式、function 包装器与 bind 绑定器
开发语言·c++·算法