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

            once setback,once inspiration,once self-awareness
            重要的是這個(gè)磨練過程,而不是結(jié)果,要的是你粗壯的腿,而不是你身上背的那袋鹽巴

             

            統(tǒng)計(jì)1的個(gè)數(shù)

            統(tǒng)計(jì)1的個(gè)數(shù)

            int ?func(x)
            {
            ????
            int ?countx? = ? 0 ;
            ????
            while (x)
            ????
            {
            ????????countx
            ++ ;
            ????????x?
            = ?x & (x - 1 );
            ????}

            ????
            return ?countx;
            }
            ?

            假定x?
            = ? 9999
            10011100001111
            答案:?
            8


            將x轉(zhuǎn)化為2進(jìn)制,看含有的1的個(gè)數(shù)

            x
            = x & (x - 1 )?這種算法是把一個(gè)二進(jìn)制數(shù)最右邊的一個(gè)1變成0

            然后呢?

            x
            - 1與x區(qū)別在于最后二進(jìn)制的1

            每執(zhí)行一次x?
            = ?x & (x - 1 ),會(huì)將x用二進(jìn)制表示時(shí)最右邊的一個(gè)1變?yōu)?,因?yàn)閤 - 1將會(huì)將該位(x用二進(jìn)制表示時(shí)最右邊的一個(gè)1)變?yōu)?。

            如果是二進(jìn)制100,
            - 1 ,則為011

            如果是二進(jìn)制101,
            - 1則為100

            與原數(shù)一與,就1后面的數(shù),包括1全都與掉

            明白,謝謝了?

            不客氣


            思路: 將x轉(zhuǎn)化為2進(jìn)制,看含有的1的個(gè)數(shù)。
            注: 每執(zhí)行一次x = x&(x-1),會(huì)將x用二進(jìn)制表示時(shí)最右邊的一個(gè)1變?yōu)?,因?yàn)閤-1將會(huì)將該位(x用二進(jìn)制表示時(shí)最右邊的一個(gè)1)變?yōu)?。(1) 如果一個(gè)數(shù)是2的n次方,那么這個(gè)數(shù)用二進(jìn)制表示時(shí)其最高位為1,其余位為0。
            判斷一個(gè)數(shù)(x)是否是2的n次方

            #include? < stdio.h >

            int ?func(x)
            {
            ????
            if (?(x & (x - 1 ))? == ? 0 ?)
            ????????
            return ? 1 ;
            ????
            else
            ????????
            return ? 0 ;
            }


            int ?main()
            {
            ????
            int ?x? = ? 8 ;
            ????printf(
            " %d\n " ,?func(x));
            ?}

            posted on 2008-04-02 09:17 snowball 閱讀(1141) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 算法+數(shù)據(jù)結(jié)構(gòu)

            導(dǎo)航

            留言簿(1)

            隨筆分類

            友情鏈接

            搜索

            最新隨筆

            最新評(píng)論

            閱讀排行榜

            伊人久久大香线蕉AV色婷婷色| 国产精品毛片久久久久久久 | 亚洲成色999久久网站| 69久久精品无码一区二区| 久久九九有精品国产23百花影院| 人人狠狠综合久久亚洲婷婷| 久久精品国产色蜜蜜麻豆| 香蕉久久夜色精品国产尤物| 久久国产欧美日韩精品| 精品无码久久久久久久动漫| 狠狠色丁香久久婷婷综合| 久久99精品国产一区二区三区| 欧美日韩精品久久久免费观看| 国产69精品久久久久久人妻精品| 国产精品99久久久久久猫咪| 亚洲精品无码久久久影院相关影片| 国产精品久久毛片完整版| 狠狠色狠狠色综合久久| 久久强奷乱码老熟女网站| 国产精品久久99| 狼狼综合久久久久综合网| 一本久久综合亚洲鲁鲁五月天| 成人资源影音先锋久久资源网| 亚洲а∨天堂久久精品9966| 中文字幕亚洲综合久久2| 久久99热只有频精品8| 久久精品国产99久久久古代 | 色欲综合久久中文字幕网| 久久久91人妻无码精品蜜桃HD| 97久久精品午夜一区二区| 亚洲综合熟女久久久30p| 亚洲午夜久久久| 久久久久99精品成人片三人毛片| 一本大道加勒比久久综合| 996久久国产精品线观看| 久久99久久99小草精品免视看| 欧洲精品久久久av无码电影| 亚洲AV无码成人网站久久精品大| 精品久久久久久久久中文字幕| 2021少妇久久久久久久久久| aaa级精品久久久国产片|