面试经典 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;
    }
}
相关推荐
MonkeyKing71555 小时前
iOS 开发基础架构与运行机制(面试高频考点)
ios·面试
MonkeyKing71557 小时前
iOS 开发 RunLoop 底层原理与应用场景
ios·面试
香蕉鼠片8 小时前
面试过程中被问懵
面试·职场和发展
用户11489669441059 小时前
Promise解析
javascript·面试
晚风予卿云月9 小时前
【Linux】Linux2.6 O(1)调度器超详解 | 进程切换+内核链表 | 面试必背
linux·运维·面试
野犬寒鸦10 小时前
Claude Code:终端AI编程助手全指南(附带指令全讲解)
开发语言·后端·面试·ai编程
天真小巫11 小时前
2026.5.10总结
职场和发展
IT策士11 小时前
Python 面试系列:常见 100 个经典面试问题,从入门到进阶
开发语言·python·面试
Rkgua12 小时前
路径传参和查询传参和请求体传参区以及Vue和React的用法区分
前端·面试
宵时待雨12 小时前
优选算法专题6:模拟
数据结构·c++·算法·leetcode·职场和发展