LeetCode第80题删除有序数组中的重复项 II

继续打卡算法题,今天学习的是LeetCode第80题删除有序数组中的重复项 II,这道题目是道中等题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些提升。

分析一波题目

本题要求原地处理原数组,删除重复项,并且只能使用O(1)的额外空间。

由于是有序的,我们只要把未超过2个重复的数字记录下来就可以了。

怎么记录呢,使用一个slow下标表示需要记录的数字,一个fast下标用于循环原数组,一个pre字段记录前一个数字,一个字段count对某个数字计数。这就是双指针的做法。

循环原数组,依次按上图规律,把需要保留的数保留下来,最终slow指针指向最后一个数字的后一位,也就是保留下来的数的长度。

本题解题技巧

1、使用双指针,慢指针记录需要保留下来的下标,快指针遍历原数组。

编码解决

java 复制代码
class Solution {
    public int removeDuplicates(int[] nums) {

        int slow = 1;
        int pre = nums[0];
        int count = 1;
        for (int fast=1; fast<nums.length; fast++) {
            if (pre == nums[fast]) {
                count++;
                if (count <=2) {
                    nums[slow] = nums[fast];
                } else {
                //相同的元素超过2个,跳过
                    continue;
                }
            } else {
                 pre = nums[fast];
                 count = 1;
                 nums[slow] = nums[fast];
            }
            slow++;
        }
        return slow;
    }
}

总结

1、双指针处理一维数组很有用,特别是有序的数组,可以提高遍历的效率。

相关推荐
城事漫游Molly1 分钟前
AI 快速生成标准化问卷分析报告:从 SUS 到 UMUX-LITE,如何把“分数”写成“结论”
人工智能·算法·机器学习·论文笔记·科研统计·问卷设计
念何架构之路1 分钟前
Go pprof性能剖析
开发语言·后端·golang
zhz52142 分钟前
Spring Boot 接入国密实战:传输加密(TLCP)+ 密码加密(SM4)
java·spring boot·后端·国密·sm4
人道领域5 分钟前
【LeetCode刷题日记】617.合并二叉树(空间换安全,还是原地省内存)
java·数据结构·算法·leetcode
独自破碎E9 分钟前
机器人Java后端算法笔试题解析
java·windows·算法
我是一颗柠檬10 分钟前
【JDK8新特性】函数式接口Day2
java·开发语言·后端·intellij-idea
Trouvaille ~10 分钟前
【Redis篇】Redis 安装与启动:快速搭建一个 Redis 环境
数据库·redis·后端·ubuntu·缓存·环境搭建·安装教程
运筹vivo@12 分钟前
3043. 最长公共前缀的长度(Leetcode 每日一题)
c++·算法·leetcode·职场和发展·每日一题
Mahir0812 分钟前
Spring Boot 自动装配深度解密:从原理到自定义 Starter 实战
java·spring boot·后端·自动装配·自定义starter·大厂面试题
Mahir089 小时前
Spring 循环依赖深度解密:从问题本质到三级缓存源码级解析
java·后端·spring·缓存·面试·循环依赖·三级缓存