1-N互不相等的自然数,缺少一个找出来

1-N的自然数中,少了一个,找出这个数

O(n)空间的比较简单,下面给出几个个只需要1,2个额外变量的算法

(1)求和-容易溢出

S1=1+2+...+N=(N+1)N/2

然后遍历数列每次从S1中减去当前的数字

最后剩下的数字就是所求

为了防止溢出我们可以每次在S1大于一定的数字后,就去减,然后继续求和,再大于就继续减,以此类推。

(2)异或

Y1=1^2^3...^N

然后遍历数列每次异或当前的数字

最后剩下的就是要求的数字

实际上平时我们用的比较多的互逆运算有 加/减   乘/除 对数/幂数

往往忽略了异或也是有一定的互逆性的

(3)O(N)时间的移动-排序

将a[i]移动到a[a[i]],使得数组有序

然后找出空着的位置

(4)O(NlogN)时间的移动-排序

用快排的思想,在1-N中选取游标X对数组快排一次,如果X被放在a[X-1]的位置上那么,要找的数字在X-N之间

否则X被放在a[X-2]的位置上 要找的数字在1-X-1之间   递归求解,直到找的要找的数字

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值