面试经典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;
}

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

相关推荐
骇客野人1 分钟前
.gitignore文件常用设置
java
Jay20021115 分钟前
【机器学习】30 基于内容的过滤算法
人工智能·算法·机器学习
冰西瓜6008 分钟前
分治(二)算法设计与分析 国科大
数据结构·算法
bill4479 分钟前
BPMN2.0,flowable工作流,【用户任务】使用【任务监听器】动态设置下一步处理人
java·工作流引擎·flowable·bpmn
Cricyta Sevina10 分钟前
Java 语言多线程核心概念全解析
java·开发语言
小小晓.16 分钟前
Pinely Round 2 (Div. 1 + Div. 2)
c++·算法
shenzhenNBA18 分钟前
如何在python文件中使用日志功能?简单版本
java·前端·python·日志·log
清风拂山岗 明月照大江25 分钟前
简单文件 IO 示例:使用系统调用读写文件
开发语言·c++·算法
Hcoco_me33 分钟前
大模型面试题15:DBSCAN聚类算法:步骤、缺陷及改进方向
算法·数据挖掘·聚类