前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Remove Duplicates from Sorted Array II

Remove Duplicates from Sorted Array II

作者头像
青木
发布2018-05-28 15:55:57
3580
发布2018-05-28 15:55:57
举报

问题描述

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]

myCode

代码语言:javascript
复制
/*
 * 对一个已经有序的序列进行重复元素删除
 * 即保证序列相同元素最多出现两次
*/
class Solution1
{
public:
    int removeDuplicatesFromSortedArray(vector<int>& nums)
    {
        //当序列为空时
        if(nums.size() <= 2)
            return nums.size();

        //当序列非空时
        int index = 2;
        for(int i = 2;i<nums.size();i++)
        {
            if(nums[i] != nums[index-2])
            {

                nums[index] = nums[i];
                index++;
            }
        }
        return index;
    }
};

测试代码

代码语言:javascript
复制
#include<iostream>
#include<vector>
using namespace std;
/*
 * 对一个已经有序的序列进行重复元素删除
 * 即保证序列相同元素最多出现两次
*/
class Solution1
{
public:
    int removeDuplicatesFromSortedArray(vector<int>& nums)
    {
        //当序列为空时
        if(nums.size() <= 2)
            return nums.size();

        //当序列非空时
        int index = 2;
        for(int i = 2;i<nums.size();i++)
        {
            if(nums[i] != nums[index-2])
            {

                nums[index] = nums[i];
                index++;
            }
        }
        return index;
    }
};

//主函数
int main(void)
{

    vector<int> a;
    a.push_back(1);
    a.push_back(1);
    a.push_back(1);
    a.push_back(2);
    a.push_back(2);
    a.push_back(3);
    a.push_back(4);
    a.push_back(4);
    a.push_back(4);
    a.push_back(4);
    a.push_back(5);

    int index = a.size();
    //在删除重复元素之前
    cout<<"before:"<<endl;
    for(int i = 0;i<index;i++)
    {
        cout<<a[i]<<" ";
    }

    cout<<endl;

    //删除重复元素之后
    Solution1 s;
    int return_num = s.removeDuplicatesFromSortedArray(a);
    cout<<"after:"<<endl;
    for(int i = 0;i<return_num;i++)
    {
        cout<<a[i]<<" ";
    }
    cout<<endl;
    return 0;
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问题描述
  • myCode
  • 测试代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档