[Java][Leetcode middle] 80. 删除有序数组中的重复项 II

删除重复元素,最多只保留两个

1. 计数法

  • 第一个元素直接加入
  • 当与前一个元素相同时,计数器+1,不同时计数器恢复1;
    只有计数器小于2时,记录元素;
java 复制代码
public int removeDuplicates2(int[] nums) {
        int cnt = 1;
        int dup = 1;
        for(int i = 1; i < nums.length; i++) {
            if(nums[i] == nums[i-1]) {
                dup++;
            }else{
                dup = 1;
            }
            if(dup <=2){
                nums[cnt++] = nums[i];
            }
        }
        return cnt;
    }

2. 快慢指针法

java 复制代码
/**
 * 双指针法
 */
public int removeDuplicates3(int[] nums) {
    int cnt = 2;  // first two ele must in the array
    for(int i = 2; i < nums.length; i++) {
        if(nums[i] != nums[cnt-2]) {
            nums[cnt++] = nums[i];
        }
    }
    return cnt;
}
相关推荐
oioihoii3 分钟前
C++共享内存小白入门指南
java·c++·算法
_OP_CHEN3 分钟前
用极狐 CodeRider-Kilo 开发俄罗斯方块:AI 辅助编程的沉浸式体验
人工智能·vscode·python·ai编程·ai编程插件·coderider-kilo
Wpa.wk5 分钟前
自动化测试 - 文件上传 和 弹窗处理
开发语言·javascript·自动化测试·经验分享·爬虫·python·selenium
_OP_CHEN7 分钟前
【Python基础】(二)从 0 到 1 入门 Python 语法基础:从表达式到运算符的全面指南
开发语言·python
@淡 定8 分钟前
线程安全的日期格式化:避免 SimpleDateFormat 并发问题
java
qq_124987075310 分钟前
基于springboot框架的小型饮料销售管理系统的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·spring·毕业设计
LYFlied16 分钟前
【算法解题模板】-【回溯】----“试错式”问题解决利器
前端·数据结构·算法·leetcode·面试·职场和发展
我命由我1234516 分钟前
Python Flask 开发:在 Flask 中返回字符串时,浏览器将其作为 HTML 解析
服务器·开发语言·后端·python·flask·html·学习方法
拾忆,想起19 分钟前
设计模式:软件开发的可复用武功秘籍
开发语言·python·算法·微服务·设计模式·性能优化·服务发现
沃斯堡&蓝鸟31 分钟前
DAY28 元组和OS模块
python·元组与os模块