读书人

一个长度替N的整形数组数组中每个元

发布时间: 2012-10-17 10:25:46 作者: rapoo

一个长度为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大湿鉴定,此方法确实是一种排序算法,叫计数排序。。

读书人网 >编程

热点推荐