2013年的创新工场笔试考了:http://blog.csdn.net/huangxy10/article/details/8026464
而且应该还是一道经典的笔试面试题:http://fayaa.com/tiku/view/2/
在上面链接中,有人给出如下几种方法:
对于丢失一个数的情况:
1)用1+2+...+n减去当前输入数据的总和。时间复杂度:O(n) 空间复杂度:O(1) 【容易溢出】
2)用12...*n除以当前输入数据的总积。时间复杂度:O(n) 空间复杂度:O(1) 【容易溢出】
3)用1^2^...^n的结果在逐个异或当前输入数据。时间复杂度:O(n) 空间复杂度:O(1)
4)对输入数据排序,然后从头到尾遍历一次。时间复杂度O(nlogn) 空间复杂度O(1)
5) 对输入数据进行Hash,然后从头到尾遍历一次。时间复杂度O(n) 空间复杂度O(n)
第三种方法,个人认为是最为精妙的,因为相同的数取异或为0,0^0为0,所以最终按照该方法得到的数就是缺失的那个数。其算法复杂度准确的说为:Theta(2*n-1)。方法1和2,虽然简单,且

本文讨论了一道经典的笔试面试题:在1到n的序列中缺失了一个数,如何找出这个数。文章列举了五种不同的解决方案,包括通过求和、求积、异或以及排序和哈希的方法。特别提到了第三种方法——异或操作,被认为是最佳方案,因为它具有线性时间和常量空间复杂度。此外,作者提出了一种基于中位数位置的递归算法,其时间复杂度也是线性的,类似于二分法和中位数查找的结合。
最低0.47元/天 解锁文章
1万+

被折叠的 条评论
为什么被折叠?



