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

             

            統計1的個數

            統計1的個數

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

            ????
            return ?countx;
            }
            ?

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


            將x轉化為2進制,看含有的1的個數

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

            然后呢?

            x
            - 1與x區別在于最后二進制的1

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

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

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

            與原數一與,就1后面的數,包括1全都與掉

            明白,謝謝了?

            不客氣


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

            導航

            留言簿(1)

            隨筆分類

            友情鏈接

            搜索

            最新隨筆

            最新評論

            閱讀排行榜

            色8久久人人97超碰香蕉987| 久久青青草原精品影院| 国色天香久久久久久久小说| 久久香蕉国产线看观看精品yw| 久久精品中文闷骚内射| 久久久精品久久久久久| 亚洲精品国产第一综合99久久| 亚洲伊人久久精品影院| 国产精品久久久久影院嫩草| 久久久久国产精品熟女影院| 国产成人综合久久久久久| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 久久精品人成免费| 久久国产香蕉视频| 国产情侣久久久久aⅴ免费| 久久天天婷婷五月俺也去| 久久精品国产亚洲网站| 三级三级久久三级久久| 久久99精品久久久久久不卡| 色综合久久无码中文字幕| 免费精品久久久久久中文字幕 | 久久久久人妻一区二区三区vr | 97久久国产亚洲精品超碰热 | 精品久久久久久中文字幕大豆网| 日本免费一区二区久久人人澡 | 天天影视色香欲综合久久| 麻豆精品久久精品色综合| 久久精品国产亚洲AV高清热| 精品久久久久久无码不卡| 蜜臀久久99精品久久久久久| 久久国产热这里只有精品| 国产AV影片久久久久久| Xx性欧美肥妇精品久久久久久| 精品国产一区二区三区久久| 国产精品禁18久久久夂久| 国产成人久久精品区一区二区| 婷婷五月深深久久精品| 久久精品国产亚洲av麻豆色欲 | 精品无码人妻久久久久久| 久久综合综合久久狠狠狠97色88| 国产精品一久久香蕉产线看|