面试经典 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 小时前
01-C#.Net-泛型-面试题
java·开发语言·面试·c#·.net
独自破碎E3 小时前
前后端分离+微服务架构下的用户认证
java·面试·架构
发现一只大呆瓜3 小时前
Vue-Vue2与Vue3核心差异与进化
前端·vue.js·面试
Byron__3 小时前
HashMap面试知识点
java·面试·hash
发现一只大呆瓜3 小时前
Vue2:数组/对象操作避坑大全
前端·vue.js·面试
发现一只大呆瓜3 小时前
Vue3:ref 与 reactive 超全对比
前端·vue.js·面试
victory04314 小时前
Agent 面试知识树 + 高频追问答案库
网络·面试·职场和发展
swipe5 小时前
JavaScript 对象操作进阶:从属性描述符到对象创建模式
前端·javascript·面试
星辰_mya7 小时前
ZooKeeper 分布式锁:强一致性下的“排队”哲学
分布式·zookeeper·云原生·面试·分布式锁