码迷,mamicode.com
首页 > 其他好文 > 详细

LeetCode--Remove Duplicates from Sorted Array II

时间:2015-01-13 12:38:15      阅读:134      评论:0      收藏:0      [点我收藏+]

标签:leetcode   array   

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

class Solution 
{
public:
    int removeDuplicates(int A[], int n) 
    {
        if(n==0 || n==1 || n==2)
            return n;
        int loc=1;
        int count = 1;
        int flag = A[0];
        for(int i=1; i<n&&A[i]>=A[i-1];i++)
        {
            if(A[i] == flag)
            {
                count++;
                if(count < 3)
                {
                    swap(A,i,loc);
                    loc++;
                }
            }
            else
            {
                flag = A[i];
                swap(A,i,loc);
                count = 1;
                loc++;
            }
        }
        return loc;
        
    }
    void swap(int* a, int i, int j)
    {
        int t = a[i];
        a[i] = a[j];
        a[j] = t;
    }
};


LeetCode--Remove Duplicates from Sorted Array II

标签:leetcode   array   

原文地址:http://blog.csdn.net/shaya118/article/details/42673723

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!