[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;
}
相关推荐
Java后端的Ai之路4 小时前
【Python 教程15】-Python和Web
python
侠客行03175 小时前
Mybatis连接池实现及池化模式
java·mybatis·源码阅读
蛇皮划水怪5 小时前
深入浅出LangChain4J
java·langchain·llm
冬奇Lab5 小时前
一天一个开源项目(第15篇):MapToPoster - 用代码将城市地图转换为精美的海报设计
python·开源
老毛肚7 小时前
MyBatis体系结构与工作原理 上篇
java·mybatis
风流倜傥唐伯虎7 小时前
Spring Boot Jar包生产级启停脚本
java·运维·spring boot
二十雨辰7 小时前
[python]-AI大模型
开发语言·人工智能·python
Yvonne爱编码8 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
Re.不晚8 小时前
JAVA进阶之路——无奖问答挑战1
java·开发语言
你这个代码我看不懂8 小时前
@ConditionalOnProperty不直接使用松绑定规则
java·开发语言