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

            醬壇子

            專注C++技術 在這里寫下自己的學習心得 感悟 和大家討論 共同進步(歡迎批評!!!)

              C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              66 Posts :: 16 Stories :: 236 Comments :: 0 Trackbacks

            公告

            王一偉 湖南商學院畢業(yè) 電子信息工程專業(yè)

            常用鏈接

            留言簿(19)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 387834
            • 排名 - 64

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            方法1:
            //main.cpp
            #include <iostream>

            using namespace std;
            ?
            int count_ones(int n)

            {

            ?????? n = (n & 0x55555555) + ((n & 0xaaaaaaaa) >> 1);

            ?????? n = (n & 0x33333333) + ((n & 0xcccccccc) >> 2);

            ?????? n = (n & 0x0f0f0f0f) + ((n & 0xf0f0f0f0) >> 4);

            ?????? n = (n & 0x00ff00ff) + ((n & 0xff00ff00) >> 8);

            ?????? n = (n & 0x0000ffff) + ((n & 0xffff0000) >> 16);

            ?

            ?????? return n;

            }

            ?

            int main(int argc,char* argv[])

            {
            ?????? cout<<count_ones(255)<<endl;

            ?????? return 0;
            }

            方法2:
            const int one_in_char[256]=
            {
            ??? 0, 1, 1, 2, 1, 2,2,3
            ......
            ????????????????????????????? ,8
            }
            此為 0-255 每個數(shù)中 1 的個數(shù)。??

            int func2(int v)
            {
            ??? int n=v;
            ??? unsigned char *ptr=(unsigned char *)&n;
            ??? return one_in_char[ptr[0]]+one_in_char[ptr[1]]+one_in_char[ptr[2]]+one_in_char[ptr[3]];
            }


            本人覺得方法1更快速:)

            posted on 2006-10-16 08:35 @王一偉 閱讀(1269) 評論(4)  編輯 收藏 引用 所屬分類: 4. C++

            Feedback

            # re: 統(tǒng)計一個32位int中“1”位的個數(shù) 2007-01-05 15:34 pengkuny
            請問,count_ones的原理是什么?
            我對位操作不是很清楚  回復  更多評論
              

            # re: 統(tǒng)計一個32位int中“1”位的個數(shù) 2007-01-08 12:26 王一偉
            好的 我晚上前給你回復 寫個詳細的過程和原理給你 其實這個只需要自己自己動手算算就知道了 :)  回復  更多評論
              

            # re: 統(tǒng)計一個32位int中“1”位的個數(shù) 2007-01-08 17:39 王一偉
            n = 9

            //第一次計算 此時 n = 0000 0000 0000 0000 0000 0000 0000 1010

            0000 0000 0000 0000 0000 0000 0000 1010
            0101 0101 0101 0101 0101 0101 0101 0101 //0x55555555
            &--------------------------------------------------------------
            0000 0000 0000 0000 0000 0000 0000 0000


            0000 0000 0000 0000 0000 0000 0000 1010
            1010 1010 1010 1010 1010 1010 1010 1010 //0xaaaaaaaa
            &--------------------------------------------------------------
            0000 0000 0000 0000 0000 0000 0000 1010

            0000 0000 0000 0000 0000 0000 0000 1010
            >>1---------------------------------------------
            0000 0000 0000 0000 0000 0000 0000 0101

            0000 0000 0000 0000 0000 0000 0000 0000
            + 0000 0000 0000 0000 0000 0000 0000 0101
            ----------------------------------------------------------------
            = 0000 0000 0000 0000 0000 0000 0000 0101

            //第二次計算 此時 n = 0000 0000 0000 0000 0000 0000 0000 0101

            0000 0000 0000 0000 0000 0000 0000 0101
            0011 0011 0011 0011 0011 0011 0011 0011 //0x33333333
            &------------------------------------------------
            0000 0000 0000 0000 0000 0000 0000 0001

            0000 0000 0000 0000 0000 0000 0000 0101
            1100 1100 1100 1100 1100 1100 1100 1100
            &------------------------------------------------
            0000 0000 0000 0000 0000 0000 0000 0100

            ....... >>2

            0000 0000 0000 0000 0000 0000 0000 0001
            + 0000 0000 0000 0000 0000 0000 0000 0001
            -----------------------------------------------
            0000 0000 0000 0000 0000 0000 0000 0010

            //第三次計算 此時 n = 0000 0000 0000 0000 0000 0000 0000 0010

            0000 0000 0000 0000 0000 0000 0000 0010
            0000 1111 0000 1111 0000 1111 0000 1111 //0x0f0f0f0f
            &-----------------------------------------------
            0000 0000 0000 0000 0000 0000 0000 0010

            0000 0000 0000 0000 0000 0000 0000 0010
            1111 0000 1111 0000 1111 0000 1111 0000
            &-----------------------------------------------
            0000 0000 0000 0000 0000 0000 0000 0000
            ......>>4
            相加 還是得 0000 0000 0000 0000 0000 0000 0000 0010
            后面的就不寫了






              回復  更多評論
              

            # re: 統(tǒng)計一個32位int中“1”位的個數(shù) 2008-11-16 09:41 belo
            其實這種方法比起傳統(tǒng)方法更慢
            這是我的一個實現(xiàn)版本:
            #include <iostream>
            using namespace std;

            int count_bits1(int n)
            {
            n = (n & 0x55555555) + ((n & 0xAAAAAAAA) >> 1); //計算相鄰兩位的bit和
            n = (n & 0x33333333) + ((n & 0xCCCCCCCC) >> 2); //計算相鄰四位的bit和
            n = (n & 0x0F0F0F0F) + ((n & 0xF0F0F0F0) >> 4); //計算相鄰八位的bit和
            n = (n & 0x00FF00FF) + ((n & 0xFF00FF00) >> 8); //計算相鄰16位的bit和
            n = (n & 0x0000FFFF) + ((n & 0xFFFF0000) >> 16); //計算相鄰32位的bit和

            return n;
            }

            int count_bits2(int n)
            {
            int count = 0;
            while(n)
            {
            count++;
            n = n & (n-1);
            }

            return count;
            }

            int main(void)
            {
            cout << count_bits1(0xFF) << endl;
            cout << count_bits2(0xFF) << endl;

            return 0;
            }

            你可以反匯編一下,然后就知道了  回復  更多評論
              

            精品无码久久久久久久动漫| 一级女性全黄久久生活片免费| 亚洲熟妇无码另类久久久| 亚洲国产精品无码久久久不卡| 国产Av激情久久无码天堂| 精品久久久久久无码人妻蜜桃| 2021国产精品午夜久久| 亚洲精品国精品久久99热一| 国产精品视频久久久| 精品久久久久成人码免费动漫| 久久永久免费人妻精品下载| 久久精品国产亚洲5555| 中文无码久久精品| 久久99精品久久久久久不卡| 无码人妻久久一区二区三区免费| 国产亚洲成人久久| 国产精品久久久久aaaa| 亚洲午夜久久久久久噜噜噜| 久久亚洲天堂| 欧美精品福利视频一区二区三区久久久精品 | 国内精品久久久久影院一蜜桃| 欧美精品丝袜久久久中文字幕 | 久久精品无码一区二区WWW| 狠狠色丁香婷婷久久综合不卡 | 日本福利片国产午夜久久| 久久亚洲春色中文字幕久久久| 国产精品乱码久久久久久软件| 久久精品综合一区二区三区| 久久天堂AV综合合色蜜桃网 | 漂亮人妻被黑人久久精品| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 欧美熟妇另类久久久久久不卡| 国产69精品久久久久APP下载| 青青热久久国产久精品 | 99久久99久久久精品齐齐| 亚洲av伊人久久综合密臀性色| 久久久久亚洲国产| 7777久久久国产精品消防器材| 99久久这里只精品国产免费| 欧美日韩精品久久免费| 99久久精品国产一区二区|