• <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>
            posts - 6,  comments - 30,  trackbacks - 0
               本人由于剛接觸編程不久,思考的問題沒有大家的那么深入。這次我僅僅只是一點基于學(xué)習(xí)的思考。今天在家里復(fù)習(xí)學(xué)校學(xué)過的功課,關(guān)于運算操作符的那一章節(jié)。  編寫一個程序:從界面輸入一個整數(shù),要求求該數(shù)除以8后的余數(shù)。這個題目確實很簡單,只要用%運算即可。但是我寫出代碼后發(fā)現(xiàn)編譯器對于負(fù)數(shù)求模運算后所得的余數(shù)是負(fù)數(shù)。當(dāng)然大家很容易想到此時加上除數(shù)即可達(dá)到題目的要求。我想這個代碼大都會寫,我就不再細(xì)述,但是今天我想輸?shù)梅椒ú⒉皇谴恕R粋€整型(int)占4個字節(jié),每個字節(jié)8位。那么每個int占32個位。如果我們把該整數(shù)化成8進制,那么其8進制表示的數(shù)的個位數(shù)就是所求的余數(shù)。因為如果一個8進制數(shù)是xyz,那么其等于x*8*8+y*8+z;除以8取余就是z;那么我們再聯(lián)想到計算機的存儲數(shù)據(jù)的方式,二進制。而二進制轉(zhuǎn)化成8進制的最簡單的方法則是將該二進制從右至左按每三個數(shù)為一單元轉(zhuǎn)化為8進制作為一位。不夠的補0;那么由此可知,其正余數(shù)就是該數(shù)二進制表示的末尾3位數(shù)。 那么只要用與運算去保留后三位。即該數(shù)與上二進制(111)即可,而從界面輸入的是10進制,則要考慮轉(zhuǎn)化,很容易知道其為7。故設(shè)輸入的數(shù)位num,則num&7所得結(jié)果即是。

            而對于2的n次方作為除數(shù)是則只要num&(2的n次方-1)
             1#include<iostream>
             2using namespace std;
             3
             4int main()
             5{
             6    int num;//輸入的整數(shù)
             7    int i;//由于考慮除數(shù)不同,在此自己設(shè)置除數(shù)2的n次方
             8    cout<<"請輸入一個整數(shù):";
             9    cin>>num;
            10    cout<<"請輸入除數(shù):";
            11    cin>>i;
            12    num=num&(i-1);
            13    cout<<num<<endl;
            14    return 0;
            15}

             

            posted on 2011-02-03 21:17 あ維wêiセ 閱讀(3940) 評論(5)  編輯 收藏 引用 所屬分類: C++

            FeedBack:
            # re: 關(guān)于除以2的n次方求余數(shù)的思考
            2011-02-11 19:26 | Cunch
            想法不錯, 希望共同切磋  回復(fù)  更多評論
              
            # re: 關(guān)于除以2的n次方求余數(shù)的思考
            2011-02-11 19:27 | Cunch
            想法確實不錯  回復(fù)  更多評論
              
            # re: 關(guān)于除以2的n次方求余數(shù)的思考[未登錄]
            2011-02-11 21:13 | zero
            貌似很久前就有這道面試題了?   回復(fù)  更多評論
              
            # re: 關(guān)于除以2的n次方求余數(shù)的思考
            2011-02-13 10:08 | あ維wêiセ
            嗯?是嗎?那我還要倍感慶幸呢@zero
              回復(fù)  更多評論
              
            # re: 關(guān)于除以2的n次方求余數(shù)的思考[未登錄]
            2011-12-07 08:37 | zhang
            好像法  回復(fù)  更多評論
              
            <2011年2月>
            303112345
            6789101112
            13141516171819
            20212223242526
            272812345
            6789101112

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            国产精品久久影院| 无夜精品久久久久久| 日本久久久久亚洲中字幕| 热re99久久6国产精品免费| 久久精品国产亚洲AV电影| 国产精品久久永久免费| 久久精品国产一区二区三区不卡 | 久久久久久毛片免费播放| 国产综合久久久久久鬼色| 91久久精品视频| 久久免费的精品国产V∧| 精品久久人人妻人人做精品| 久久国产欧美日韩精品| 久久成人影院精品777| 一本久久综合亚洲鲁鲁五月天| 久久Av无码精品人妻系列| 四虎久久影院| 91性高湖久久久久| 久久精品午夜一区二区福利| 欧美一区二区久久精品| 国内精品久久久久影院网站| 久久ZYZ资源站无码中文动漫| 久久国产亚洲精品| 久久99热这里只有精品国产| 久久99精品国产| 99国产精品久久久久久久成人热| 色婷婷久久综合中文久久一本 | 久久婷婷五月综合97色直播| 91视频国产91久久久| 人人狠狠综合久久88成人| 国产精品久久婷婷六月丁香| 人妻无码久久精品| 久久毛片免费看一区二区三区| 国产精品成人久久久久久久| 色综合久久中文综合网| 蜜桃麻豆www久久| 精品久久香蕉国产线看观看亚洲| 久久国产精品成人免费| 99久久无码一区人妻a黑| 国产精品99精品久久免费| 人人狠狠综合久久88成人|