面试经典 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;
    }
}
相关推荐
爱学测试的雨果2 小时前
收藏!软件测试面试题
开发语言·面试·职场和发展
文涛是个小白呀2 小时前
Java集合大调研
java·学习·链表·面试
五点六六六2 小时前
双非同学校招笔记——离开字节入职小📕
前端·面试·程序员
川Princess3 小时前
【面试经验】梅赛德斯奔驰X-Seed AI Systems - Autonomous Driving Agent Efficiency二面
面试·职场和发展
Heo4 小时前
Webpack高级之常用配置项
前端·javascript·面试
用户84913717547164 小时前
从源码看设计:Java 集合框架的安全性与性能权衡 (基于 JDK 1.8)
java·面试
编程小Y4 小时前
配置Associated Domains时,需要注意哪些细节?
职场和发展·蓝桥杯
xiaoxue..5 小时前
栈的全面解析:ADT、实现与应用
javascript·数据结构·面试
sulikey8 小时前
深入讲解:什么是 RAII(资源获取即初始化)——原理、实现、面试常考点与实战示例
c++·面试·智能指针·raii·shared_ptr·auto_ptr·资源获取即初始化