本文主要是介绍剑指offer03:数组中重复的数组---leetcode:LCR 120. 寻找文件副本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
设备中存有 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)。
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;
}
使用哈希,使用数组中的值作为下标,进行标记。防止数组中值溢出,使用取余的办法。
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;
}
这篇关于剑指offer03:数组中重复的数组---leetcode:LCR 120. 寻找文件副本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!