• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            那誰(shuí)的技術(shù)博客

            感興趣領(lǐng)域:高性能服務(wù)器編程,存儲(chǔ),算法,Linux內(nèi)核
            隨筆 - 210, 文章 - 0, 評(píng)論 - 1183, 引用 - 0
            數(shù)據(jù)加載中……

            如何使用位操作得到大于N且為2的次方的最小的數(shù)

            RT,比如輸入10返回16, 輸入24返回32,等等.


            注意,是使用位操作且沒(méi)有循環(huán),也不用表驅(qū)動(dòng)等等.因?yàn)檫@個(gè)操作要經(jīng)常進(jìn)行,要保證高效,所以不能使用循環(huán)(別跟我說(shuō)用遞歸,熟悉算法和計(jì)算機(jī)本質(zhì)的人都知道遞歸和循環(huán)本質(zhì)是一樣的:);同時(shí),因?yàn)椴恢佬枰?jì)算的數(shù)據(jù)到底有多大,采用表驅(qū)動(dòng)的辦法也不可行.

            我在網(wǎng)上發(fā)帖,最終得到了一個(gè)很BT的答案:
            int fun(int v)
            {
                
            float f = (float)(v - 1);  
                
            return 1 << ((*(unsigned int*)(&f) >> 23- 126);
            }

            但是我不知道這個(gè)算法的原理是什么,貌似采用了浮點(diǎn)數(shù)格式的一些特性,知道的同學(xué)請(qǐng)給我一個(gè)詳盡的解釋,在這里先感謝了.

            posted on 2008-06-21 15:36 那誰(shuí) 閱讀(4783) 評(píng)論(10)  編輯 收藏 引用 所屬分類: C\C++ 、算法與數(shù)據(jù)結(jié)構(gòu)

            評(píng)論

            # re: 如何使用位操作得到大于N且為2的次方的最小的數(shù)  回復(fù)  更多評(píng)論   

            很邪惡啊,我還是喜歡簡(jiǎn)單一些的。。。

            int fun(int v)
            {
            int res = 1;
            while (res < v)
            res <<= 1;

            return res;
            }
            2008-06-21 16:36 | 大日如來(lái)

            # re: 如何使用位操作得到大于N且為2的次方的最小的數(shù)  回復(fù)  更多評(píng)論   

            其實(shí)也不復(fù)雜,只要知道float在內(nèi)存里是怎么存儲(chǔ)的就簡(jiǎn)單的很了
            IEEE:
            float:
            Sign Exponent Mantissa
            1bit 8bits 23bits

            實(shí)際上float的Mantissa是24位,有一個(gè)隱含的最高位,且該位一直為‘1’

            Mantissa表示1~2之間的數(shù)
            Expoent=0x7f表示指數(shù)0, Expoent>0x7f為正指數(shù),Expoent<0x7f則為負(fù)指數(shù)
            2008-06-21 16:41 | 大日如來(lái)

            # re: 如何使用位操作得到大于N且為2的次方的最小的數(shù)  回復(fù)  更多評(píng)論   

            和BIG-ENDIAN or LITTLE_ENDIAN有關(guān),推薦少用。
            2008-06-21 16:51 | 大日如來(lái)

            # re: 如何使用位操作得到大于N且為2的次方的最小的數(shù)  回復(fù)  更多評(píng)論   

            @大日如來(lái)
            我不覺(jué)得和大小端有關(guān)系,浮點(diǎn)寄存器和整數(shù)寄存器在內(nèi)存存取上是一致的。
            2008-06-22 17:50 | Louix

            # re: 如何使用位操作得到大于N且為2的次方的最小的數(shù)  回復(fù)  更多評(píng)論   

            剛才做實(shí)驗(yàn)驗(yàn)證了一下,這個(gè)方法是有Bug的,使用float類型會(huì)造成轉(zhuǎn)換時(shí)的進(jìn)位,使用double就可以了,求數(shù)字二進(jìn)表示長(zhǎng)度的代碼:
            double dTarget = ( double )target;
            return ( ( *( ( ( unsigned int * ) &dTarget ) + 1 ) ) >> 20 ) - 1023;
            這樣的代碼就和大小端相關(guān)了,而且沒(méi)有其他版效率高。
            2008-06-22 18:45 | Louix

            # re: 如何使用位操作得到大于N且為2的次方的最小的數(shù)  回復(fù)  更多評(píng)論   

            答案是很BT的,我是想不到
            2008-06-22 23:00 | 影視劇

            # re: 如何使用位操作得到大于N且為2的次方的最小的數(shù)  回復(fù)  更多評(píng)論   

            這個(gè)算法只是玩一玩了,有助于了解IEEE標(biāo)準(zhǔn)浮點(diǎn)數(shù)的構(gòu)造。
            實(shí)際應(yīng)用中整形和浮點(diǎn)的相互轉(zhuǎn)換很花時(shí)間,還不如一步步位移來(lái)做。
            2008-06-25 09:20 | RedNax

            # re: 如何使用位操作得到大于N且為2的次方的最小的數(shù)  回復(fù)  更多評(píng)論   

            解決問(wèn)題的關(guān)鍵在于如何找到二進(jìn)制表示時(shí)第一個(gè)‘1’出現(xiàn)的位置?!?’出現(xiàn)在第n位,則將1左移n位即可。
            v - 1是不必要的,意圖可能是想去掉大日如來(lái)所說(shuō)的“隱含的最高位1”,直接轉(zhuǎn)就可以了,要了反而算出的結(jié)果不對(duì),不是float類型轉(zhuǎn)換進(jìn)位的問(wèn)題。
            f右移23位為的是得到存儲(chǔ)在Exponent里的(n-1)+127=n+126,127是常量。再減去126求得n。
            利用浮點(diǎn)數(shù)存儲(chǔ)格式來(lái)找到這個(gè)n確實(shí)是我沒(méi)想到的,想出這個(gè)解法的人思維很發(fā)散。
            2008-07-21 15:51 | wolfssss

            # re: 如何使用位操作得到大于N且為2的次方的最小的數(shù)  回復(fù)  更多評(píng)論   

            @wolfssss
            float f = (float)(v - 1);
            v減不減一的區(qū)別在于

            float f = (float)(v - 1);
            求的是大于等于N且為2的次方的最小的數(shù)

            float f = (float)(v);
            求的是大于N且為2的次方的最小的數(shù)
            2011-10-16 12:16 | 楚天清秋

            # re: 如何使用位操作得到大于N且為2的次方的最小的數(shù)  回復(fù)  更多評(píng)論   

            可以下ieee 754 就明白了
            2013-02-22 17:07 | mankeyl
            狠狠精品干练久久久无码中文字幕| 亚洲AV无码久久精品蜜桃| 97久久精品人妻人人搡人人玩| 久久精品人人槡人妻人人玩AV | 精品久久综合1区2区3区激情| 久久久久亚洲AV无码专区桃色 | 2021久久精品免费观看| 精品无码久久久久久尤物| 亚洲国产精品久久久久久| 99久久这里只精品国产免费| 久久精品国产亚洲网站| 色偷偷88欧美精品久久久 | A级毛片无码久久精品免费| 97久久国产亚洲精品超碰热| 欧美日韩成人精品久久久免费看| 久久99国产精品久久99| 人妻无码精品久久亚瑟影视 | 久久91这里精品国产2020| 成人午夜精品无码区久久| 欧美成a人片免费看久久| www.久久99| 亚洲va中文字幕无码久久不卡| 伊人久久五月天| 久久99国产精品一区二区| 99久久精品国产一区二区| 亚洲国产精品嫩草影院久久 | 少妇内射兰兰久久| 亚洲国产精品综合久久一线| 国产成人精品久久一区二区三区av | 亚洲中文久久精品无码| 久久黄色视频| 国产成人久久精品二区三区| 国产精品久久久久久久久| 久久夜色精品国产欧美乱| 综合久久一区二区三区| 久久免费大片| 一级做a爰片久久毛片毛片| 日本亚洲色大成网站WWW久久| 欧美日韩精品久久免费| 日韩中文久久| 久久婷婷五月综合色奶水99啪|