• <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>
            源于無聊, 又再看了復習了下"不用臨時變量進行整型變量交換"

            兩種流行方法:
            (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 }

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

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

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

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

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

            (2)
            用強制轉換吧, (int)0x*,
            *是什么, 0x7fffffff
            惡心-_-||, 我一開始又4個f了, 一個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++標準方法..
            //直接貼過來了
            //前面有說明說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 }



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

            Copyright © 藍塵

            久久精品卫校国产小美女| 亚洲精品乱码久久久久久久久久久久 | 久久久久久国产精品无码超碰 | 99久久国语露脸精品国产| 久久久久久久99精品免费观看| 国产成人精品综合久久久| 无码任你躁久久久久久老妇| 日产精品久久久一区二区| 狠狠色综合久久久久尤物| 精品久久久无码21p发布| 韩国三级中文字幕hd久久精品| 一级做a爰片久久毛片毛片| 狠狠色丁香婷综合久久| 久久综合色老色| 久久精品中文字幕一区| 国产成年无码久久久久毛片| 伊人久久大香线蕉综合5g| 久久免费精品一区二区| 久久久免费精品re6| 国产亚洲精久久久久久无码77777| 精品国产一区二区三区久久久狼| 一本综合久久国产二区| 国产成人精品久久综合 | 欧美精品福利视频一区二区三区久久久精品 | 久久久亚洲AV波多野结衣| 精品久久人人妻人人做精品 | 久久99国产综合精品| 中文字幕无码久久久| 久久国产福利免费| 免费精品99久久国产综合精品| 亚洲精品高清国产一线久久| 亚洲色大成网站www久久九| 午夜精品久久久久久| 久久精品国产清自在天天线| 伊人热人久久中文字幕| 国产亚洲欧美成人久久片| 久久中文娱乐网| 国内精品久久久久久不卡影院| 久久久久久国产a免费观看不卡 | 久久免费线看线看| 日韩精品国产自在久久现线拍|