数组去重

Posted jianbo1995

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数组去重相关的知识,希望对你有一定的参考价值。

class solution
{
public:
    int removeDuplicate(vector<int>& nums)
    {
        if(nums.empty())
            return 0;
        int index = 0;
        for(int i=0;i<nums.size();i++)
        {
            if(nums[index]!=nums[i])
                nums[++index] = nums[i];
        }
        return index+1;
    }
};

这是给出的第一种方法,发现并不好使,因为实际上是简单的前移,没有使得向量容器的实际长度发生变化,因此,改进后的算法:

技术分享图片
class solution
{
public:
    int removeDuplicate(vector<int>& nums)
    {
        if(nums.empty())
            return 0;
        int index = 0;
        for(int i=0;i<nums.size();i++)
        {
            if(nums[index]!=nums[i])
                nums[++index] = nums[i];
        }
        nums.erase(nums.begin()+index+1,nums.end());
        return index+1;
    }
};
View Code

第二种是利用现有的去重函数unique 在algorithm中,功能是将重复的内容扔到尾部,没有删除处理,返回指向非重复尾部的迭代器指针

下面是第二种方法的代码:


class Solution
{
public:
int removeDuplicates(vector<int>& nums)
{
nums.erase(unique(nums.begin(), nums.end()),nums.end());
return nums.size();
}
};


第一种方法有一定的限制,即数组事先需要经过排序,这里注意erase的用法,是从当前位置(包含)删除至尾部位置(不包含)

以上是关于数组去重的主要内容,如果未能解决你的问题,请参考以下文章

C/C++系列数组去重代码实现

C/C++系列数组去重代码实现

C/C++系列数组去重代码实现

用最简短的代码搞定数组去重

php 多个 一维数组 去重 组成新数组

ES6 - 一条代码实现数组去重