首页 > 其他 > 详细

[leetcode] Remove Duplicates from Sorted Array II

时间:2014-07-03 11:50:46      阅读:283      评论:0      收藏:0      [点我收藏+]

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].

https://oj.leetcode.com/problems/remove-duplicates-from-sorted-array-ii/

 

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

 

bubuko.com,布布扣
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

 

 

参考:

http://www.programcreek.com/2013/01/leetcode-remove-duplicates-from-sorted-array-ii-java/

http://zhangxc.com/2013/11/leetcode-remove-duplicates-from-sorted-array-2

[leetcode] Remove Duplicates from Sorted Array II,布布扣,bubuko.com

[leetcode] Remove Duplicates from Sorted Array II

原文:http://www.cnblogs.com/jdflyfly/p/3815544.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!