• <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
            重要的是這個磨練過程,而不是結(jié)果,要的是你粗壯的腿,而不是你身上背的那袋鹽巴

             

            統(tǒng)計1的個數(shù)

            統(tǒng)計1的個數(shù)

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

            ????
            return ?countx;
            }
            ?

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


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

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

            然后呢?

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

            每執(zhí)行一次x?
            = ?x & (x - 1 ),會將x用二進制表示時最右邊的一個1變?yōu)?,因為x - 1將會將該位(x用二進制表示時最右邊的一個1)變?yōu)?。

            如果是二進制100,
            - 1 ,則為011

            如果是二進制101,
            - 1則為100

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

            明白,謝謝了?

            不客氣


            思路: 將x轉(zhuǎn)化為2進制,看含有的1的個數(shù)。
            注: 每執(zhí)行一次x = x&(x-1),會將x用二進制表示時最右邊的一個1變?yōu)?,因為x-1將會將該位(x用二進制表示時最右邊的一個1)變?yōu)?。(1) 如果一個數(shù)是2的n次方,那么這個數(shù)用二進制表示時其最高位為1,其余位為0。
            判斷一個數(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 閱讀(1156) 評論(0)  編輯 收藏 引用 所屬分類: 算法+數(shù)據(jù)結(jié)構(gòu)

            導(dǎo)航

            留言簿(1)

            隨筆分類

            友情鏈接

            搜索

            最新隨筆

            最新評論

            閱讀排行榜

            国产精品久久久久…| 久久久久av无码免费网| 7国产欧美日韩综合天堂中文久久久久| 亚洲人成伊人成综合网久久久| 激情伊人五月天久久综合| 国产 亚洲 欧美 另类 久久| 亚洲国产精品无码久久一区二区 | 精品无码久久久久国产动漫3d| 久久亚洲精品成人AV| 777久久精品一区二区三区无码| 久久亚洲日韩看片无码| 国产精品禁18久久久夂久| 婷婷久久综合九色综合绿巨人| www.久久精品| 亚洲AV无一区二区三区久久 | 久久精品女人天堂AV麻| 久久综合88熟人妻| 亚洲AV伊人久久青青草原| 日本一区精品久久久久影院| 亚洲色大成网站WWW久久九九| 日韩精品国产自在久久现线拍 | 久久中文精品无码中文字幕| 九九99精品久久久久久| 人妻精品久久久久中文字幕69| 久久国产视频99电影| 91精品国产色综久久| 久久免费视频观看| 国产精品9999久久久久| 1000部精品久久久久久久久| 中文字幕无码精品亚洲资源网久久| 狠狠人妻久久久久久综合| 99久久国产热无码精品免费久久久久| 久久久久99精品成人片直播| 亚洲国产另类久久久精品黑人 | 狠狠色丁香久久婷婷综合| 三级三级久久三级久久| 精品国产日韩久久亚洲| 女同久久| 久久www免费人成看片| 97久久婷婷五月综合色d啪蜜芽| 欧美精品乱码99久久蜜桃|