亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
12
最近訪問板塊 發(fā)新帖
樓主: creating2008
打印 上一主題 下一主題

如何求一個數(shù)據(jù)最接近2的冪的數(shù). [復制鏈接]

論壇徽章:
0
11 [報告]
發(fā)表于 2009-01-14 16:08 |只看該作者
原帖由 fera 于 2009-1-14 12:37 發(fā)表

不錯
我的想法跟你差不多,不過我的效率低:
察看二進制是否全為1
是:返回+1
否:用最高位所在位置對2求冪并返回改值


這個方法仍然有瑕疵,比如1111可以得到正確值16,但是1110就會得到8,不能算最優(yōu)值。
我覺得不如就用最笨的查表法,建立一個0到64位冪值的表,然后逐一查詢,遇到合適的兩個值也可求差值決定最優(yōu)的值。
作為工程應用的話64位應該差不多了,反正這樣以來復雜度是最小的,而且一定可以得到最優(yōu)值。

當然這個辦法弱智了點,估計大家都想到了,就是想鉆鉆牛角尖弄個更牛點的方法而已~

論壇徽章:
0
12 [報告]
發(fā)表于 2009-01-14 16:28 |只看該作者
原帖由 NalaGinrut 于 2009-1-14 16:08 發(fā)表


這個方法仍然有瑕疵,比如1111可以得到正確值16,但是1110就會得到8,不能算最優(yōu)值。
我覺得不如就用最笨的查表法,建立一個0到64位冪值的表,然后逐一查詢,遇到合適的兩個值也可求差值決定最優(yōu)的值。
作 ...

恩~
我沒考慮周到
其實判斷第二高位是否為1就行。
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術有限公司. 版權所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關心和支持過ChinaUnix的朋友們 轉載本站內容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP