面试经典 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;
    }
}
相关推荐
LYFlied17 分钟前
【每日算法】LeetCode 416. 分割等和子集(动态规划)
数据结构·算法·leetcode·职场和发展·动态规划
坚持学习前端日记1 小时前
软件开发完整流程详解
学习·程序人生·职场和发展·创业创新
萧曵 丶2 小时前
ArrayList 和 HashMap 自动扩容机制详解
java·开发语言·面试
张老师Plus4 小时前
依依东望,望的是时间
经验分享·程序人生·面试·职场和发展·跳槽
小高0074 小时前
🔥3 kB 换 120 ms 阻塞? Axios 还是 fetch?
前端·javascript·面试
千寻girling4 小时前
面试官 : “ Vue 选项式api 和 组合式api 什么区别? “
前端·vue.js·面试
就叫曲奇饼干吧5 小时前
前端面试题整理(方便自己看的)
前端·面试
Bohemian6 小时前
kafka学习笔记系列——小试牛刀
面试·kafka
不想秃头的程序员7 小时前
吃透 JS 事件委托:从原理到实战,解锁高性能事件处理方案
前端·面试