面试经典 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;
    }
}
相关推荐
怕什么真理无穷1 小时前
C++_面试15_零拷贝
c++·面试·职场和发展
Espresso Macchiato1 小时前
Leetcode 3748. Count Stable Subarrays
算法·leetcode·职场和发展·leetcode hard·leetcode 3748·leetcode周赛476·区间求和
天真小巫1 小时前
2025.11.17总结
职场和发展
沐怡旸2 小时前
【穿越Effective C++】条款21:必须返回对象时,别妄想返回其reference——对象返回的语义与效率平衡
c++·面试
一叶飘零_sweeeet2 小时前
2025 年 Redis 面试天花板
redis·缓存·面试
米兰小铁匠173 小时前
js深入之从原型到原型链
javascript·面试
Java水解5 小时前
20个高级Java开发面试题及答案!
spring boot·后端·面试
Linda L7 小时前
夏鹏的《主场》讲了什么
职场和发展·创业创新·学习方法
一直在努力的小宁7 小时前
《代码随想录-精华内容提取》07 二叉树
数据结构·算法·链表·面试