面试经典 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;
    }
}
相关推荐
睡觉然后上课4 小时前
c基础面试题
c语言·开发语言·c++·面试
xgq4 小时前
使用File System Access API 直接读写本地文件
前端·javascript·面试
一叶祇秋4 小时前
Leetcode - 周赛417
算法·leetcode·职场和发展
邵泽明6 小时前
面试知识储备-多线程
java·面试·职场和发展
戊子仲秋6 小时前
【LeetCode】每日一题 2024_10_2 准时到达的列车最小时速(二分答案)
算法·leetcode·职场和发展
夜流冰7 小时前
工具方法 - 面试中回答问题的技巧
面试·职场和发展
penguin_bark8 小时前
LCR 068. 搜索插入位置
算法·leetcode·职场和发展
杰哥在此14 小时前
Python知识点:如何使用Multiprocessing进行并行任务管理
linux·开发语言·python·面试·编程
GISer_Jing20 小时前
【React】增量传输与渲染
前端·javascript·面试
Neituijunsir1 天前
2024.09.22 校招 实习 内推 面经
大数据·人工智能·算法·面试·自动驾驶·汽车·求职招聘