面试经典 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;
    }
}
相关推荐
Croa-vo1 小时前
逆袭Akuna Quant!美硕秋招亲历,从网申到拿offer全攻略
数据结构·经验分享·算法·面试·职场和发展
拉不动的猪2 小时前
基本数据类型Symbol的基本应用场景
前端·javascript·面试
沐怡旸2 小时前
【底层机制】Android OTA更新系统:原理与应用深度解析
android·面试
Swift社区2 小时前
LeetCode 427 - 建立四叉树
算法·leetcode·职场和发展
YoungHong19924 小时前
面试经典150题[066]:分隔链表(LeetCode 86)
leetcode·链表·面试
吃饺子不吃馅5 小时前
优化:如何避免 React Context 引起的全局挂载节点树重新渲染
前端·面试·github
小白程序员成长日记7 小时前
2025.11.18 力扣每日一题
算法·leetcode·职场和发展
代码程序猿RIP8 小时前
【C++开发面经】全过程面试问题详解
java·c++·面试
ssshooter8 小时前
传参优于外部变量
前端·后端·面试