题:给定一个整数数组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";
}

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

被折叠的 条评论
为什么被折叠?



