时间复杂度为o(N)查找1至N-1构成的a[N]重复元素
Sailor_forever [email protected] 转载请注明
http://blog.csdn.net/sailor_8318/archive/ 2008/10/12 /3059935.aspx
××××××××××××××××××××××××××××××××××
数组a[N],1至N-1这N-1个数存放在a[N]中,其中某个数重复一次。写一个函数,找出被重复的数字。时间复杂度必须为o(N)函数原型:
int do_dup(int a[],int N)
××××××××××××××××××××××××××××××××××
假金条的数学思想
此算法题借鉴了假金条的思想,不过比那个过程简单,存放1至N-1,就相当于依次从各个袋中取出1至N-1个金条,但是有一个是重的,计算这N个数的和将相当于称总重量,减去1至N-1的和(用数学方法求)就可求出来重复的数。总之要充分利用数学知识
const int N = 5;
int a[N]={2,1,3,1,4};
int tmp1 = 0;
int tmp2 = 0;
for (int i=0; i<N; ++i)
{
tmp1+=(i+1);
tmp2+=a[i];
}
printf("重复的数:%d/n",N-(tmp1-tmp2));
上述方法求1~N的和,减去数组总和,即为N-x 的差值,x为待找的数
可以优化的是1-N