oracle资源正忙:我想知道如何十进制数转二进制数的最快算法。

来源:百度文库 编辑:杭州交通信息网 时间:2024/05/01 08:12:51
比如:11111110
有什么方法可以很快的判断出他的二进制是多少?

就是用逐步相除的方法,有点像小学时的求最大公约数,一直到不能除为止。
如用2逐步除63,求余数,按位数放置即可。
2|63
31--1 (个位)
15--1 (第二位)
7--1 (第三位)
3--1 (第四位)
1--1 (第五位)
所以63表示为二进制时为11111
同时1023可表示为1100110111 (注意,当最后出现结果和余数都为1时两个都要算)
2|32767
16383--1
8191--1
4095--1
2047--1
1023--1
...同上
32767可表示为110011011111111
65535表示为:111011110101

该回答在2006-01-08 13:43:56由回答者修改过

最快?
计算机一点马上出来!

用短除法