设备中存有 n
个文件,文件 id
记于数组 documents
。若文件 id
相同,则定义为该文件存在副本。请返回任一存在副本的文件 id
。
示例 1:
输入:documents = [2, 5, 3, 0, 5, 0]
输出:0 或 5
提示:
0 ≤ documents[i] ≤ n-1
2 <= n <= 100000
思路,排序之后再看,原本以为是要返回重复的数组,打算用一个空数组做标记,结果只需返回一个重复的即可。
使用排序后的数组,找挨着的两个即可。排序的时间复杂度是O(nlogn),而找到重复元素的时间复杂度是O(n)。
cpp
int compare(const void* a,const void* b){
return *(int*)a-*(int*)b;
}
int findRepeatDocument(int* documents, int documentsSize) {
qsort(documents,documentsSize,sizeof(int),compare);
for(int i=0;i<documentsSize-1;i++){
int j=1;
if(documents[i]==documents[i+j]){
return documents[i];
}
}
return 0;
}
使用哈希,使用数组中的值作为下标,进行标记。防止数组中值溢出,使用取余的办法。
cpp
int findRepeatDocument(int* documents, int documentsSize){
int* hash=(int*)malloc(documentsSize*sizeof(int));
for (int i = 0; i < documentsSize; i++) {
hash[i] =-1;
}
for(int i = 0; i < documentsSize; i++){
int p=documents[i]%documentsSize;
if(hash[p]!=-1){
return documents[i];
}
hash[documents[i]%documentsSize]=documents[i];
}
return 0;
}