• <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)塵

            四虎国产精品成人免费久久| 国内精品伊人久久久久AV影院| 狠狠狠色丁香婷婷综合久久俺| 天天综合久久久网| 久久亚洲2019中文字幕| 国产亚洲精久久久久久无码77777| 无码伊人66久久大杳蕉网站谷歌| 日韩精品久久久久久| 久久久久久伊人高潮影院| 久久成人精品视频| 久久精品国产日本波多野结衣| 国产精品99久久久久久人| 久久婷婷午色综合夜啪| 日本免费久久久久久久网站| 国内精品久久久久影院薰衣草| 国产高清美女一级a毛片久久w | 久久精品成人免费观看97| 99久久精品免费看国产一区二区三区 | 天堂久久天堂AV色综合| 国产精品成人99久久久久91gav| 伊人色综合久久天天网| 久久成人精品| 亚洲成人精品久久| 精品久久久久中文字幕日本| 国产一区二区久久久| 久久国产影院| 久久不见久久见免费影院www日本| 狠狠狠色丁香婷婷综合久久五月 | 日本福利片国产午夜久久| 国产成人精品久久免费动漫| 亚洲AV日韩精品久久久久久久| 亚洲国产精品嫩草影院久久| 欧美色综合久久久久久| 亚洲国产成人乱码精品女人久久久不卡| 国产免费福利体检区久久| 国产福利电影一区二区三区久久老子无码午夜伦不 | 99久久这里只精品国产免费| 精品国产91久久久久久久a| 久久黄色视频| 精品久久久久久无码不卡| 伊人久久大香线蕉综合热线|