一看题目这么长,聪明的你肯定已经猜到了这是个标题党。
据说这个某个公司的招聘题,某个追求时间和空间极限的bt程序员某个时间脑袋灵光一闪,搞出来这些个所谓的nb算法,然后再自豪地把它们呈给那些技术面试官,让他们用这些来测测我们这些普通程序员的脑袋是否灵光。然而,网络的发达或许让他们的这一想法完全落空,本来就是些高中生都能看懂的算法(似乎我没有夸张),加上网络一传播,地球人都知道了。所以到最后,也只能考考那些从未看过类似我这篇Blog的人:)。所以,我自己倒是更愿意把这个归为一道智力测试题。
国外已经有很多专家在质疑智力测试的准确性,在知识能够迅速获取的今天,很多智力题目只要你做过一次,第二次就不再是智力测试,而是记忆力测试了。所以很奇怪为什么现在面试官对智力测试有一种不可思议地喜欢,我们姑且称之为"智力测试喜好症候群"。
好了,言归正传,看过这篇Blog的ggmm以后面试碰上这种题目就不用经过大脑了,可以脱口而出,或者脱笔而出,或者脱X而出了(Coding,那是脱什么来着?)。
//不用temp的整数交换,一点点数学上的trick:)
void NotempSwap(int& a, int& b)
{
a = a + b;
b = a - b;
a = a - b;
}
关于时间复杂度为O(n)以及空间复杂度为O(1)的整数排序算法,实际上是有前提的,面试官一般会这么问:
给定1000000个数,这些数都在0~65535之间,设计一个算法,将这