面试经典 150 题 ---- 删除排序数组中的重复项

面试经典 150 题 ---- 删除排序数组中的重复项

删除排序数组中的重复项

方法一:双指针

有是一个原地修改的题目,大概率依旧是双指针。

定义 right 表示遍历数组到达的下标位置,left 指针表示下一个不同元素将要填入的下标位置,两个指针初始都指向 1。

java 复制代码
class Solution {
    public int removeDuplicates(int[] nums) {
        int len = nums.length;
        int left = 1, right = 1;
        while (right < len) {
            if (nums[right] != nums[right - 1]) {
                nums[left] = nums[right];
                left ++ ;
            }
            right ++ ;
        }
        return left;
    }
}
相关推荐
不会写DN8 分钟前
IPv4 与 IPv6 的核心区别
计算机网络·面试·golang
chh5639 分钟前
C++--内存管理
java·c语言·c++·windows·学习·面试
June bug1 小时前
【ISTQB-CTFL(基础级)】错题D卷
经验分享·职场和发展
小欣加油1 小时前
leetcode 42 接雨水
c++·算法·leetcode·职场和发展
We་ct2 小时前
JS手撕:函数进阶 & 设计模式解析
开发语言·前端·javascript·设计模式·面试·前端框架
凌波粒2 小时前
LeetCode--459.重复的子字符串(字符串/KMP算法)
算法·leetcode·职场和发展
逆境不可逃2 小时前
【后端新手谈09】深入浅出短链接:从原理到实战开发
算法·面试·职场和发展
yuki_uix2 小时前
当 reduce 遇到二维数据:从"聚合直觉"到"复合 Map"的思维跃迁
前端·javascript·面试
我叫黑大帅2 小时前
Vue3中的computed 与 watch 的区别
前端·javascript·面试
yuki_uix2 小时前
前端解题的 6 个思维模型:比记答案更有用的东西
前端·面试