面试经典 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;
    }
}
相关推荐
用户3958561421142 小时前
从理论到实践:哪些EMBA项目真正提供“干货”课程?
面试
Wect2 小时前
JSX & ReactElement 核心解析
前端·react.js·面试
Lee川18 小时前
JavaScript 面向对象编程全景指南:从原始字面量到原型链的终极进化
javascript·面试
千寻girling1 天前
一份不可多得的 《 Django 》 零基础入门教程
后端·python·面试
SuperEugene1 天前
Vue生态精选篇:Element Plus 的“企业后台常用组件”用法扫盲
前端·vue.js·面试
Neptune11 天前
JavaScript回归基本功之---类型判断--typeof篇
前端·javascript·面试
离开地球表面_991 天前
金三银四程序员跳槽指南:从简历到面试再到 Offer 的全流程准备
前端·后端·面试
UrbanJazzerati1 天前
Scrapling入门指南:零基础也能学会的网页抓取神器
后端·面试
比尔盖茨的大脑1 天前
事件循环底层原理:从 V8 引擎到浏览器实现
前端·javascript·面试
Qinana1 天前
从 URL 输入到页面展示:一场跨越进程与协议的“装修”大戏
前端·面试·程序员