某度算法题:含重复元素数组保持稳定去重

本文介绍了一种基于桶排序思想的数组去重算法,通过两次遍历实现数组元素的去重并保持原有的顺序。首先确定输入数组的元素范围,然后利用桶数组记录每个元素是否首次出现,从而高效地移除重复项。

题:给定一个整数数组arr,其中元素可能重复,要求返回去重后的数组,且去重保持稳定,也就是把重复的第二个元素去掉而保留第一个元素。

解:利用通排序的思想,第一次遍历输入数组,确定元素大小区间[min,max],然后申请max-min+1的桶数组bukarr,全部初始化成[min,max]区间之外的某个不会出现在输入数组元素区间内的数比如min-1。然后构造输出数组newarr,第二次遍历输入数组,对元素x,其在桶数组内的下标就是x-min,先检查bukarr[x-min]是否已经被标记1,如果没有被标记1过,说明当前元素x是第一次出现,那压栈到newarr,然后标记1;如果元素x已经被标记1过,说明当前元素x不是第一次出现,跳过x。

代码:

#include<iostream>
#include<vector>
std::vector<int> getSingle(std::vector<int> arr){
    //第一次遍历找到输入数组元素区间
    int min(1<<30),max(-1*(1<<30));
    for(int &rele:arr){
        min=rele<min?rele:min;
        max=rele>max?rele:max;
    }
    int *tagarr=new int[max-min+1];
    for(int i(0);i<max-min+1;i++)tagarr[i]=min-1;   //标记用一个不可能出现的元素
    //第二次遍历,考察元素是否已经出现过
    std::vector<int> newarr;    //大小不定,不知道重复了多少个元素
    for(int &rele:arr){
        if(tagarr[rele-min]==min-1){ //第一次出现
            newarr.push_back(rele); //压栈
            tagarr[rele-min]=1; //标记
        }else if(tagarr[rele-min]==1){ //前面已经出现过,跳过
        }
        continue;
    }
    return newarr;
}
int main(int argc,char *argv[]){
    std::vector<int> arrin;
    int arr[]={3,1,4,1,5,9,5,6};
    for(int i(0);i<8;i++)arrin.push_back(arr[i]);
    std::vector<int> arrout(getSingle(arrin));
    for(int &rele:arrout)std::cout<<rele<<"\t"; //3       1       4       5       9       6
    std::cout<<"\n";
}

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值