周围的每一寸空间似乎都堆放着各式各样的电子设备和元器件,光线昏暗,拥挤不堪,林鸿觉得自己仿佛来到了大陆某个城市中城隍庙的电子市场。
走了一段路程之后,他看到,和电脑有关的电子配件和元器件逐渐多了起来。
前面,一个前额刘海染成黄色的青年正在店铺中玩着电脑游戏。
这个时候,走在前面的黄越突然站住了,他转头对广永元道:按照老规矩。
说完,他便独自一人先朝前面走了。
老规矩林鸿用疑惑地眼神看了广永元一眼。
广永元只好解释道:要想进入这个圈子,必须证明自己的技术已经达到这个水平。虽然他们都认识我,但他们都是死脑筋,只认技术不认人。
绕来绕去,林鸿总算明白,要想继续向前走,他必须通过他们设置的考验,颇有点闯关的意味。
有意思。林鸿笑笑,对此并不在意,问道,都有些什么项目
广永元道:编程破解以及网络渗透。当然,并不一定要全部过关,只要其中一项能够得到他们的认可就行了。你肯定是没有问题的,只是走个过场罢了。
广永元已经见识过林鸿的破解技术,连英雄无敌这样难啃的骨头林鸿都三下五除二不费什么力气就搞定了,更何况是他们的入门考验
这个时候,之前正在玩游戏的染发青年已经退出游戏,他一甩额头的黄发对林鸿道:请吧。
第一道关卡,编程。
林鸿也没有什么废话,坐到了刚刚青年的座位,他看到,显示器中已经出现了一道题目很显然,他们对于这种事情已经非常熟悉,拥有了自己一套固定的考验流程。
给林鸿出的题目为使用基本运算来编写一个你所可能实现的效率最高的平方根函数。
平方根在数学中是一个非常重要同时也非常复杂的运算,在计算机中实现这种函数通常比较困难,所以编程语言一般都会对这些函数进行封装,程序员在编程的时候,如果涉及到平方根运算,直接调用函数库中的函数就行了很少有人会懂得底层到底是如何实现的。
而且,能够实现是一方面,能不能做到运算效率高效又是另外一方面。
程序的运行效率,往往就是高手和菜鸟之间的重要区别,真正的黑客,编程的时候,不仅仅只是将功能实现,还会追求最高效率有时候可能只是一个符号的变化,其执行效率便天差地别。
执行一次的区别可能看不出来,可是如果循环一千次,一万次呢
高手和菜鸟编写的程序,在效率上往往有着很多倍的差距,要想编写出高效优雅的程序必须有着对编程语言和计算机底层的本质理解,同时还得拥有丰富的编程经验,在这方面可做不得假实践是唯一提高自身实力的方式。
林鸿知道,求平方根的运算,有一个算法叫做牛顿迭代法,其原理为:
如果一个数为x,假设它的平方根为y如果y的平方和x相差大于某个给定的误差′就继续假设下一个值,如此持续下去直到最终得到在允许误差内的值。
至于如何假设这个值,使用的方式便是取平均值其中必须多次用到除法和乘法。
在计算机中,其本质其实就是加法,整个cpu的运算其实就是一个加法器,当初林鸿实现超脑cpu结构的时候,就是基于一个加法器结构,至于后面的减法乘法以及除法等运算,都是对在这个加法器的基础上衍伸而来。
直接使用牛顿迭代法来求平方根,这是普通人的做法,林鸿不用想都知道,如果真的按照这种方式来实现,显然不能过关。
林鸿略微一思索便有了头绪,他查看了一下电脑中的编译器,发现这台电脑里面准备得非常充分,不但有市面上常见的一些编程语言编译器,如cbaiscjavac等语言,甚至还有一些非常小众的编程语言,如adablueisp等等。
最终,林鸿还是调出了电脑中的c语言编译器,直接敲起代码来。
霹雳啪啦,仅仅过了二十来秒之后,林鸿便完成了函数的编写。
他调用用函数执行了一下,程序成功运行,没有任何地错误,一次通过。
想了想,他再次删掉了两行,将两个步骤合并成了一个,最终的函数代码总数正好为十行。
好了。林鸿道。
站在他身后的广永元此刻还在皱着眉头看着他的程序。
他想不通,林鸿为什么这么编写。
这么快就好了染发青年有些诧异。
刚刚他让出座位的时候,便从一个角落拿出了一个掌上游戏机玩了起来,可是刚刚才开始玩,便听到林鸿说已经ok。
这在众多挑战者当中,还是头一回。
染发青年俯身过去看了一眼,脸上微微一愣,林鸿写的这十行代码,虽然他能看懂大部分,但是还有几个细节他一时之间也没弄懂。
他顺手将林鸿的这个函数加入时间统计宏,执行一万次之后,最终显示出了时间,965毫秒,也就是说,不到一秒钟。
他用敬服的眼神看着林鸿,说道:你过关了。我在这里呆了两年了,两年来,从这里走过的人不下五十人,可是从来没有一个人做到你这一步,不但结果保证精度,并且执行一万次的时间不超过一秒。
林鸿笑笑,对于他的夸赞并没有什么可得意的,这些都是最基础的东西,只要理解了cpu的运作,多想一想基本上应该都能达到的,没有好得意的。
广永元这个时候出言问道:阿鸿,我看得不是很懂,求平方根不是使用二分查找法么
广永元最擅长的并不是这个方面,他毕竟是野路子出身,基础部分还不是很扎实,林鸿的这十行代码,他竟然看得满头雾水。
他口中所说的二分查找,其实就是牛队迭代法的实现方式之一。
林鸿点点头:算法的确是这个,不过在这里,我使用二进制的移位代替了乘除。你看
林鸿见他听得不是很懂,于是便重新调出编译器,下断点,跟踪变量的内存赋值,一边操作一边解释:
在二进制层面上,从前向后决定每一个二进制位上是0还是1,因此,我们可以从最高位向最低位,依次上1,看乘积结果是否大于目标数,如果大于目标数了,那一位就保留0这样的情况下,我们上1就不用真的去计算乘法,而是将之前的结果,加上上1以前的数左移1所在位置那么多位的两倍,再加上上1的位置左移上1的位置
经过林鸿演示加解说,广永元这才恍然大悟,后面的青年也释然的点点头,他虽然知道大致原理,可是在细节方面还是有些地方没有理解,听了林鸿完整的解释这才了然。
也就是说,整个算法林鸿使用的都是二进制层面的运算,想不快都难,或者说,没有哪个程序可以比他的这个算法实现更快了。
仅仅花了二十来秒的时间就搞定第一关,并且答案如此优秀,这可是之前从来没有碰到过的。
林鸿本来还想着见识一下后面到底出什么题目,不过黄越在看到林鸿的这个程序之后,便直接宣布林鸿过关了,没有必要再继续闯关。
这个题目,实际上是黄越亲自出的,他当初给了一个标准答案,也是二进制层面的实现,可是两者相比之下,还是有着相当大的差距。
这虽然是最基础的东西,但正是这些东西最是能看清楚一个人的水平。
很显然,林鸿在这方面要比黄越更强,更别说,广永元之前对他说,林鸿还是一个破解大师。
最终,林鸿顺利地进入了他们的大本营,也就是一个相当大的大厅,不过在那里,摆了上十台各种品牌的电脑和服务器,看上去反而觉得有些拥挤。
大厅之中,有不少人,都是年轻人,他们见来了新成员,有的鼓掌,有的吹口哨,表示欢迎,不过,也仅此而已,例行欢迎仪式过后,他们便再次将注意力放在了自己的电脑显示器上。
黄越给林鸿重点介绍了两个人,一个叫袁乐邦,一个胖得连腰都弯不下的胖子,有着弥勒佛一样的笑脸,擅长的领域正是游戏破解,广永元最想挖的人便是他。
另外一个是阮飞舟,带着厚厚的黑框眼镜,他擅长的是硬件破解,在他的桌子上,摆满了各种电子元器件和最新的游戏机,包括sony的游戏机和任天堂的gba和nds系列游戏机。-
在阮飞舟的身上,林鸿看到了顾伟的影子。
他们这个地方,并不是公司,甚至连一个团队都称不上,只是基于兴趣聚集在一起,黄越为他们免费提供场所,而这里是鸭寮街,任何电器和元器件都能很方便地在这里找到。
他们是一群为技术而癫狂的技术宅。