面试经典150题——删除有序数组中的重复项

面试经典150题 day3

题目来源

力扣每日一题;题序:26

我的题解

方法一 双指针

使用两个指针分别指向相同元素的左右边界,再利用一个count记录最终需要的数组长度。
时间复杂度 :O(n)
空间复杂度:O(1)

java 复制代码
public int removeDuplicates(int[] nums) {
    int left=0,right=1;
    int n=nums.length;
    if(n==1)
        return n;
    int count=0;
    while(right<n){
    	//找到相同元素的左右边界
        while(right<n&&nums[left]==nums[right])
            right++;
        //当前相同元素记录如最终的数组
        count++;
        left=right;
        right++;
        //只有left小于n时才会更新结果数组
        if(left<n)
            nums[count]=nums[left];
    }
    if(left<n)
        count++;
    return count;
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

相关推荐
椰果子9 分钟前
Nacos 2.x.x版本不适用JDK17的处理方式
java·spring boot·后端
bkspiderx42 分钟前
C++中的访问控制:private、public与protected的深度解析
开发语言·c++·算法·访问控制·private·public·protected
爱敲代码的小黄1 小时前
阿里人的 2025 年终总结:买房、晋升、订婚、投资,遇见更清晰的自己
后端·面试·架构
Wang15301 小时前
Java网络IO模型
java
人道领域1 小时前
【零基础学java】(补充可变参数和Collections)
java·intellij-idea
夏幻灵1 小时前
【Java进阶】面向对象编程第一站:深入理解类、对象与封装前言
java·开发语言
nsjqj1 小时前
JavaEE初阶:多线程(1)
java·开发语言·jvm
0xwang1 小时前
maven scope引起的程序崩溃
java·maven
ullio1 小时前
arc207c - Combine to Make Non-decreasing
算法
it运维技术圈1 小时前
斩杀线之老杨面试了一个42岁的资深大佬,他哭了
面试·职场和发展