• <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 - 183,  comments - 10,  trackbacks - 0

             

            一般面試中會(huì)有這個(gè)題目,交換兩個(gè)變量的值,不需要其他變量。

            首先是最常見(jiàn)的交換變量的方法是

            void swap(int& a, int& b)
            {
                
            int t = a;
                a 
            = b;
                b 
            = a;
            }

            這里借助了輔助變量 t。


            另一種方法是利用算數(shù)運(yùn)算

            void swap(int& a, int &b)
            {
                a 
            += b;
                b 
            = a - b;
                a 
            = a - b;
            }

            但是這種方法要考慮越界的可能,a + b 有可能越界,如果發(fā)生這種情況,這種方法就不行了。


            第三種方法是利用異或運(yùn)算

            異或運(yùn)算的原理就是 0 保持,1 取反。

            void swap(int& a, int& b)
            {
                a 
            ^= b;
                b 
            ^= a;
                a 
            ^= b;
            }

            這種方法直接進(jìn)行為運(yùn)算,不用考慮是否越界的問(wèn)題。但是要考慮 a 和 b 是否是同一個(gè)變量,如果是同一個(gè)變量,則最終的結(jié)果是 a = b = 0。

            這就達(dá)不到我們想要的交換操作了。所以這種方法應(yīng)該加一個(gè)檢測(cè)。

            void swap(int& a, int& b)
            {
                
            if (&== &b)
                {
                    
            return;
                }
                a 
            ^= b;
                b 
            ^= a;
                a 
            ^= b;
            }

             

            另外,只要 a 和 b 不是同一個(gè)變量即可實(shí)現(xiàn)交換,a = b 也不例外。

            除此之外,如果 a 和 b 的字節(jié)數(shù)不一致,則只會(huì)交換第字節(jié)位的數(shù)值,高字節(jié)位的數(shù)值保持不變。

            posted on 2011-05-19 14:43 unixfy 閱讀(174) 評(píng)論(0)  編輯 收藏 引用

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            亚洲精品国产自在久久| 久久受www免费人成_看片中文| 久久精品aⅴ无码中文字字幕不卡| 久久99热这里只有精品国产| 国产激情久久久久影院| 久久本道久久综合伊人| 欧美粉嫩小泬久久久久久久| 18禁黄久久久AAA片| 69SEX久久精品国产麻豆| 日本精品久久久中文字幕 | 一本一本久久A久久综合精品| 无码国内精品久久人妻| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久97久久97精品免视看秋霞| 久久精品亚洲欧美日韩久久| 香蕉久久夜色精品国产2020| 精品国产乱码久久久久久1区2区 | 麻豆av久久av盛宴av| 久久夜色tv网站| 性欧美丰满熟妇XXXX性久久久| 国产精品无码久久久久| 久久久久99精品成人片试看 | 无码人妻少妇久久中文字幕蜜桃| 久久青青草原国产精品免费| 亚洲AV无码久久| 久久久久久午夜精品| 很黄很污的网站久久mimi色 | 久久精品无码一区二区三区免费| 亚洲精品乱码久久久久久自慰| 91精品国产91热久久久久福利| 久久久久久精品成人免费图片| 久久国产精品国语对白| 情人伊人久久综合亚洲| 精品久久久久久国产91| 蜜臀av性久久久久蜜臀aⅴ| 2021久久精品免费观看| 无码任你躁久久久久久| 久久青青草原精品国产不卡| 久久99精品国产麻豆不卡| 国产免费福利体检区久久| 久久综合综合久久97色|