好久以前就听到的这个面试题,如今一直记忆犹新。html
有个店主有1000个苹果,有10个框。一会要来一个特殊的顾客,他说出一个须要的苹果数,而后店主不须要从新装苹果,只须要将特定的几个框给顾客便可知足他要的苹果数。问,店主事先应该如何将1000个苹果放到10个框里才能知足顾客提出的一次要求?(固然顾客说的苹果数是0到1000之间)程序员
分析上面这个状况,也就是要构造10个数,当从10个数中取出特定的数时,其和可以表示1,1000之间的全部数。面试
初看这题会以为难以想象,用10个数就能够表示[1,1000]之间的全部数!!spa
从最小的数开始一步步分析,要表示1,确定得有1吧。这时有一个数1.htm
要表示2,能够再添加一个1,也能够添加一个2.若是添加1的话,那么表示3时又要添加一个1,因此咱们选择添加2。这里有1,2blog
表示3的话,用1,2便可。get
表示4,能够再添加一个1,或者添加4。若是添加1,那么表示5时,又得添加一个1,因此直接添加4。这时有1,2,4二进制
身为程序员的咱们这里就能够看到规律了1,2,4,8,16,32....程序
因此,应该是这样放苹果1,2,4,8,16,32,64,128,256,489。最后一个框没有512个苹果了,因而将因此剩下的都放其中。思考
思考这个答案的本质:
任意整数都对其对应的二进制,好比13对应(1101)2,因此能够写成(1000)2+(100)2+(1)2
而二进制的1对应整数1,二进制的10对应2,(100)2对应4,(1000)2对应8,因此用1,2,4,8,16,...这样的数能够表示全部从1到其和之间的任意整数。
BigNumber实现小数次幂,http://www.cnblogs.com/xiangism/p/4614674.html这片文章中有介绍小数二进制的一个妙用。
回想初中时,有一次考试是用2B铅笔在答题卡上填答案,而且学号也要用2B铅笔涂出来。如今清晰地记得当时就是要咱们在1,2,4,8这四个数中涂上对应的数来表示数字。当时我就很是惊讶为何这四个数就能够表示全部1到10之间的数,是怎么想出来的???? 成了程序员后最终于明白了这里的玄机……