面试经典 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;
    }
}
相关推荐
码农水水1 天前
腾讯Java面试被问:阻塞队列BlockingQueue的实现原理
java·后端·python·面试
东东的脑洞1 天前
【面试突击】深度解析:Redis 与数据库(DB)的一致性方案
数据库·redis·面试
sandyznb1 天前
go面试汇总
开发语言·面试·golang
爱学大树锯1 天前
【快刷面试】-数据库-多线程在数据库中的应用
数据库·面试·多线程
INGg__1 天前
Java面试现场:从简单到复杂
java·面试·技术
1024肥宅1 天前
面试和算法:常见面试题实现与深度解析
前端·javascript·面试
记得多喝水o1 天前
技术岗能“混”进去再学?
职场和发展
Gary Studio1 天前
面试经验积累
面试·职场和发展
C雨后彩虹1 天前
字符串拼接
java·数据结构·算法·华为·面试