一个长度替N的整形数组,数组中每个元素的取值范围是[0,N-1],写一个算法判断数组中是否存在重复的数字
一个长度为N的整形数组,数组中每个元素的取值范围是[0,N-1],写一个算法判断数组中是否存在重复的数字
一个长度为N的整形数组,数组中每个元素的取值范围是[0,N-1],写一个算法判断数组中是否存在重复的数字
bool IsDuplicateNumber(int *array, int n) { if(array==NULL) return false; int i,temp; for(i=0;i<n;i++) { while(array[i]!=i) { if(array[array[i]]==array[i]) return true; temp=array[array[i]]; array[array[i]]=array[i]; array[i]=temp; } } return false; }
把每个数放到自己对应序号的位置上,如果其他位置上有和自己对应序号相同的数,那么即为有重复的数值。
当没有重复数值出现时,可以看做一种特殊的排序。
- Re: lcytrl昨天 15:25
- 回复lyj2486n这个方法适用于要求是的[1,N-1]。如果像你说的那样,这个方法就不适用了。
- 3楼lyj2486昨天 08:20
- 发现这个 算发也不错的啊呵呵!
- 2楼falconfei昨天 08:17
- 是判断,不是查找,为也可以用求和的方式判断
- 1楼jsyao昨天 00:22
- 经lzf大湿鉴定,此方法确实是一种排序算法,叫计数排序。。