博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[leetcode] Remove Duplicates from Sorted Array II
阅读量:5279 次
发布时间:2019-06-14

本文共 2433 字,大约阅读时间需要 8 分钟。

Follow up for "Remove Duplicates":

What if duplicates are allowed at most twice?

For example,

Given sorted array A = [1,1,1,2,2,3],

Your function should return length = 5, and A is now [1,1,2,2,3].

 

思路:双指针法。只不过这次是前面隔一个元素比较。

 

public class Solution {    public int removeDuplicates(int[] A) {        int n = A.length;        if (n <= 2)            return n;        int index = 2;        for (int i = 2; i < n; i++) {            if (A[i] != A[index - 2])                A[index++] = A[i];        }        return index;    }    public int removeDuplicates2(int[] A) {        if (A.length <= 2)            return A.length;        int prev = 1; // point to previous        int curr = 2; // point to current        while (curr < A.length) {            if (A[curr] == A[prev] && A[curr] == A[prev - 1]) {                curr++;            } else {                prev++;                A[prev] = A[curr];                curr++;            }        }        return prev + 1;    }    public static void main(String[] args) {        System.out.println(new Solution().removeDuplicates(new int[] { 1, 1, 1, 2 }));        System.out.println(new Solution().removeDuplicates(new int[] { 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5 }));        System.out.println(new Solution().removeDuplicates(new int[] {}));        System.out.println(new Solution().removeDuplicates(new int[] { 1 }));        System.out.println(new Solution().removeDuplicates(new int[] { 1, 1 }));    }}
View Code

 

第二遍记录:

  总体思想还是双指针法,cur负责遍历,pre负责赋值,注意寻找移动的规则。

public int removeDuplicates(int[] A) {        if (A.length <= 2)            return A.length;         int prev = 1;         int curr = 2;          while (curr < A.length) {            if (A[curr] == A[prev] && A[curr] == A[prev - 1]) {                curr++;            } else {                prev++;                A[prev] = A[curr];                curr++;            }        }         return prev + 1;    }

 

 

好理解的解法2:

每次统计每个数字的个数count,i表示当前可以被拷贝的位置。

public class Solution {    public int removeDuplicates(int[] A) {        int i = 0;        int j = 0;        while (j < A.length) {            int count = 1;            while (j + 1 < A.length && A[j + 1] == A[j]) {                ++count;                ++j;            }            A[i++] = A[j];            if (count > 1) {                A[i++] = A[j];            }            ++j;        }        return i;    }}

  

 

 

参考:

转载于:https://www.cnblogs.com/jdflyfly/p/3815544.html

你可能感兴趣的文章
移动、尺寸改变
查看>>
c# 文件笔记
查看>>
类和结构
查看>>
心得25--JDK新特性9-泛型1-加深介绍
查看>>
安装NVIDIA驱动时禁用自带nouveau驱动
查看>>
HDU-1255 覆盖的面积 (扫描线)
查看>>
Java 中 静态方法与非静态方法的区别
查看>>
Jenkins+ProGet+Windows Batch搭建全自动的内部包(NuGet)打包和推送及管理平台
查看>>
线程池的概念
查看>>
Java 序列化
查看>>
Java 时间处理实例
查看>>
Java 多线程编程
查看>>
Java 数组实例
查看>>
mysql启动过程
查看>>
2017前端面试题总结
查看>>
Http GetPost网络请求
查看>>
SWIFT国际资金清算系统
查看>>
Sping注解:注解和含义
查看>>
站立会议第四天
查看>>
如何快速掌握一门技术
查看>>