• <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>

            單鏈DNA

            換了個地址:http://www.cnblogs.com/vizhen/

             

            計算二進制中1的個數

            編寫一個函數返回數字的二進制位中‘1’的個數。

             

            方法一,遞歸

            int findOneinBin(int n)
            {
               if(n<2)
                  return 1;
              else return n%2+findOneinBin(n/2);
            }

            這個方法很容易想到,如果是奇數的話就是他的n/2+1,也就是有一位加上1個1.

            方法二,google一下找出來的,沒看懂

            #define POW(c) (1<<(c))
            #define MASK(c) (((unsigned long)-1) / (POW(POW(c)) + 1))
            #define ROUND(n, c) (((n) & MASK(c)) + ((n) >> POW(c) & MASK(c)))
            
            int bit_count(unsigned int n)
            {
                n = ROUND(n, 0);
                n = ROUND(n, 1);
                n = ROUND(n, 2);
                n = ROUND(n, 3);
                n = ROUND(n, 4);
                return n;
            }

            一下子看不明白,先把宏展開來:
            POW是計算2的冪
            MASK很奇怪,一個全1的無符號數字除以2的冪的冪加1?
            好在打印出來還能看得懂:

            MASK(0) = 55555555 h = 01010101010101010101010101010101 b
            MASK(1) = 33333333 h = 00110011001100110011001100110011 b
            MASK(2) = 0f0f0f0f h = 00001111000011110000111100001111 b
            MASK(3) = 00ff00ff h = 00000000111111110000000011111111 b
            MASK(4) = 0000ffff h = 00000000000000001111111111111111 b

            這些mask分別把32位數字劃分為幾個部分。每個部分的前一半和后一半分別是全'0'和全'1'。
            MASK(0)分為16個部分,MASK(1)分為8個部分,...
            ROUND中對n的處理:(n & MASK) + (n >> POW & MASK)
            POW的值剛好是MASK中連續'0'(或者連續'1')的長度。也就是說ROUND把由MASK分開的n的各個部分中的高POW位和低POW位相加。
            為了便于說明,取一個簡單的部分:MASK(1)的0011
            假設n的值為1001,那么ROUND后的結果就是10 + 01 = 11 b,把這個結果賦值給n,這時n的含義由原來的二進制位串變為'1'位的數量。特別的,當ROUND(n, 0)時,把n當作一個32個部分各自'1'位的數量。('0'表示沒有'1',而'1'則表示有1個'1')
            計算完n = ROUND(n, 0)后,n是一個16個部分各自'1'位數量的'數組',這個'數組'的每個元素只有2個二進制位。最大值為2,足夠由2個二進制位來表示。
            接下來,計算完n=ROUND(n,1)后,n是一個8個部分各自'1'位數量的'數組',這個'數組'的每個元素只有4個二進制位。最大值為4,足夠由4個二進制位來表示。(實際只需要3個二進制位)
            ...
            最后一步,計算n=ROUND(n,4)后,n是一個1個部分各自'1'位數量的'數組',這個'數組'的每個元素有32個二進制位。最大值為32,足夠由32個二進制位來表示。(實際只需要6個二進制位)
            這個代表32位內'1'位數量的32位二進制數也就是我們要求的結果。

            posted on 2011-02-24 16:12 Geek.tan 閱讀(850) 評論(0)  編輯 收藏 引用

            導航

            統計

            公告

            coding是我的寂寞,我是誰的寂寞

            隨筆分類(40)

            隨筆檔案(48)

            搜索

            積分與排名

            最新評論

            評論排行榜

            国产精品99久久免费观看| 久久夜色精品国产| 97r久久精品国产99国产精| 97久久精品午夜一区二区| 久久综合综合久久狠狠狠97色88| 91精品久久久久久无码| 久久综合视频网站| 亚洲va久久久噜噜噜久久天堂| 久久综合九色综合97_久久久| 性做久久久久久久久| 久久91精品国产91久久小草 | 国产精品久久久久久五月尺| 亚洲精品无码久久久久去q| 中文字幕亚洲综合久久| 久久精品久久久久观看99水蜜桃| 国产精品久久国产精麻豆99网站| 精品久久久久成人码免费动漫 | 亚洲精品乱码久久久久久中文字幕| 久久精品黄AA片一区二区三区| 欧美与黑人午夜性猛交久久久| 国产欧美一区二区久久| 亚洲精品乱码久久久久久蜜桃图片| 国产免费久久精品丫丫| 久久精品中文字幕无码绿巨人| 中文成人无码精品久久久不卡| 亚洲狠狠综合久久| 精品久久久久久久| 久久国产亚洲高清观看| 久久久亚洲欧洲日产国码aⅴ| 91麻豆国产精品91久久久| 久久国产精品一区| 国内精品久久久久久久涩爱| 国产99久久久久久免费看| 久久精品国产半推半就| 99久久无码一区人妻a黑| 久久久噜噜噜久久中文福利| 看久久久久久a级毛片| 亚洲AV无一区二区三区久久| 久久精品aⅴ无码中文字字幕不卡| 香蕉99久久国产综合精品宅男自 | 青青草原精品99久久精品66|