面试经典 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;
    }
}
相关推荐
Haooog几秒前
微服务篇面试题(不定时更新)
微服务·面试·架构
Croa-vo8 分钟前
NVIDIA 2025 Deep Learning & Systems 岗位面试复盘 | C++并发与底层架构难度解析
c++·深度学习·面试
知其然亦知其所以然30 分钟前
JavaScript 变量的江湖恩怨:一篇文章彻底讲清楚
前端·javascript·面试
摇滚侠42 分钟前
索引失效,数据库引擎,索引失效的六种情况
数据库·面试
进击的野人1 小时前
Vue生命周期详解:从创建到销毁的全过程
前端·vue.js·面试
鹏北海1 小时前
微前端实现方式:HTML Entry 与 JS Entry 的区别
前端·javascript·面试
yaoh.wang1 小时前
力扣(LeetCode) 9: 回文数 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
Java天梯之路1 小时前
Spring Boot 钩子全集实战(二):`SpringApplicationRunListener.starting()` 详解
java·spring·面试
测试人社区-千羽1 小时前
语义分析驱动的测试用例生成:提升软件测试效率的新范式
运维·人工智能·opencv·面试·职场和发展·自动化·测试用例
ywwwwwwv2 小时前
力扣300
算法·leetcode·职场和发展