• <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>
            源于無聊, 又再看了復(fù)習(xí)了下"不用臨時(shí)變量進(jìn)行整型變量交換"

            兩種流行方法:
            (1) 加減減
            1 void AsExchang(int &x, int &y)
            2 {
            3      x = x + y;
            4      y = x - y;
            5      x = x - y;
            6 }
            7 

            (2) 異或
            1 void XorExchang(int &x, int &y)
            2 {
            3      x = x ^ y;
            4      y = x ^ y;
            5      x = x ^ y;
            6 }

            兩種方法, 都可以認(rèn)識(shí)是密碼學(xué)的一部分吧, 只是用加減法來加密, 幼稚且缺乏安全性而已.
            當(dāng)然, 異或法在現(xiàn)實(shí)中也得變種才能實(shí)際應(yīng)用

            一開始傻傻地聯(lián)想到方法一是否存在越界問題... //基礎(chǔ)知識(shí)瞬間薄弱化...
            系統(tǒng)底層的實(shí)現(xiàn)居然一時(shí)間忘記了...

            聯(lián)想到如何確認(rèn)一個(gè)類型能表示的最大最小值
            (1)
            所以想到的用sizeof運(yùn)算符, 判斷類型的位數(shù), 然后笨笨地左移右移操作進(jìn)行計(jì)算
            int getMaxInt()
            {
                
            int iBase= 1;
                
            const int IntSize = sizeof(int* 8;

                
            //int是有符號(hào)數(shù), 最左邊一位是符號(hào)位
                
            //so
                for(int i = 1; i < IntSize - 1 ; i++ )
                {
                    iBase 
            = (iBase << i) + 1;
                }

                
            return iBase; 
            }
            好笨的方法...
            很沒效率

            (2)
            用強(qiáng)制轉(zhuǎn)換吧, (int)0x*,
            *是什么, 0x7fffffff
            惡心-_-||, 我一開始又4個(gè)f了, 一個(gè)f才4位吧...

            (3)
            還有用bitset, bitsit有to_ulong方法, 湊合著用

            (4)
            climits的 INT_MAX
            在cplusplus.com上面的reference是顯示
            INT_MAX  Maximum value for an object of type int
             = 32767
            被他的圖表騙了

            VC6版本的頭文件里面是用
            #define INT_MAX  2147483647 
            直接定義的
            查看cywin里面的頭文件
            也差不多..
            #define __INT_MAX__ 2147483647
            #define INT_MAX __INT_MAX__


            (5)
            C++標(biāo)準(zhǔn)方法..
            //直接貼過來了
            //前面有說明說numeric_limits<int>::max()等于INT_MAX
            //... 只是封裝了模板而已
             1 // numeric_limits example
             2 #include <iostream>
             3 #include <limits>
             4 using namespace std;
             5 
             6 int main () {
             7   cout << boolalpha;
             8   cout << "Minimum value for int: " << numeric_limits<int>::min() << endl;
             9   cout << "Maximum value for int: " << numeric_limits<int>::max() << endl;
            10   cout << "int is signed: " << numeric_limits<int>::is_signed << endl;
            11   cout << "Non-sign bits in int: " << numeric_limits<int>::digits << endl;
            12   cout << "int has infinity: " << numeric_limits<int>::has_infinity << endl;
            13   return 0;
            14 }



            沒去找高手們的奇招, 浪浪蕩蕩又消費(fèi)了不少時(shí)間...
            繼續(xù)潛修去

            Copyright © 藍(lán)塵

            欧美激情精品久久久久久久九九九| 久久亚洲国产成人影院| 91久久精一区二区三区大全| 91精品国产综合久久婷婷| 日韩一区二区久久久久久| 久久亚洲色一区二区三区| 亚洲国产精品久久久天堂| 久久综合丝袜日本网| 亚洲国产成人久久笫一页| 久久久久99精品成人片试看| 久久久久久国产精品美女| 久久久久久久久久久久中文字幕 | 久久精品无码专区免费东京热 | 人妻无码αv中文字幕久久琪琪布| 人妻精品久久久久中文字幕69 | 免费精品久久天干天干| 国产精品岛国久久久久| 无码8090精品久久一区| 久久精品一区二区国产| 久久天天躁狠狠躁夜夜avapp | 狠狠色丁香久久婷婷综合图片| 久久A级毛片免费观看| 伊人热热久久原色播放www| 国产真实乱对白精彩久久| 久久久女人与动物群交毛片| 欧美精品丝袜久久久中文字幕 | 久久精品国产一区二区| 欧美牲交A欧牲交aⅴ久久| 香蕉久久夜色精品国产2020| 久久国产综合精品五月天| 久久精品国产精品青草| 久久精品99久久香蕉国产色戒| 久久精品国产亚洲AV久| 久久婷婷色综合一区二区| 深夜久久AAAAA级毛片免费看 | 伊人久久大香线焦AV综合影院| 久久人人爽人爽人人爽av| 亚洲国产精品狼友中文久久久| 久久性生大片免费观看性| 亚洲国产精品狼友中文久久久 | 亚洲国产精品一区二区久久hs|