C语言 数组中重复的数字分析及方法
2017-03-19 09:52
465 查看
C语言 数组中重复的数字解决方法:
题目:在一个长度为n的数组里的所有数字都在0-n-1的 范围内。数组中某些数字是重复的,但是不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是重复的数字2或者3.
解法1:对于数组进行排序,之后对于已经排序的数组进行遍历便可知道数组中重复的数字。
时间复杂度;O(nlogn);
解法2:建立一个大小为O(N)的哈希表,遍历数组中的元素并判断是否存在于哈希表中。若不存在于哈希表中,将这个元素加入哈希表之中并且继续扫描,若这个元素存在于哈希表中,则:找到了数组中重复的一个数字;
时间复杂度:O(N),空间复杂度:O(N);
解法3:对于给定的数组进行重排。对于下标为i的元素:如果a[i] == i,扫描下一个元素;如果不相等将a[i]与a[a[i]]进行比较,若是相等则找到了一个重复的数字,若没有,那么对于数字进行交换,依次进行。
int DuplicateInArray(int arr[],int size) { int i=0; while(i<size) { if(arr[i] == i) ++i; else { if(arr[i] != arr[arr[i]]) {swap(arr[i],arr[arr[i]]);} else {return arr[i];} } } return -1; }
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣的文章:
相关文章推荐
- C语言查找数组里数字重复次数的方法
- 【我解C语言面试题系列】008 去除数组中重复数字问题
- 去掉有序数组中重复数字 原地 leetcode java (最简单的方法)
- 【C语言】数组--字符串初始化数组的方法分析
- C语言计算一维数组重复数字(最大)的个数及数字所有位置
- c语言排序后删除数组中重复的数字再排序输出
- php实现数组纵向转横向并过滤重复值的方法分析
- 数组删除重复的数字1方法一:
- 【我解C语言面试题系列】009 特殊的去除数组中重复数字问题
- 【我解C语言面试题系列】008 去除数组中重复数字问题
- 【我解C语言面试题系列】009 特殊的去除数组中重复数字问题
- 数组删除重复的数字1方法二:
- javascript如何判断数组内元素是否重复的方法集锦
- C语言中字符数组和字符串指针分析
- PHP中常用数组处理方法实例分析
- 防止刷新重复提交数据解决方法的分析
- 防止刷新重复提交数据解决方法的分析
- 防止刷新重复提交数据解决方法的分析
- 数组a[N],存放了1至N-1个数,其中某个数重复一次。写一个函数,找出被重复的数字.时间复杂度必须为o(N)函数原型:
- 可用的ASP无重复数字随机函数, 数组实现, 并应用于随机显示记录集