• <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>
            源于無(wú)聊, 又再看了復(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é)的一部分吧, 只是用加減法來(lái)加密, 幼稚且缺乏安全性而已.
            當(dāng)然, 異或法在現(xiàn)實(shí)中也得變種才能實(shí)際應(yīng)用

            一開(kāi)始傻傻地聯(lián)想到方法一是否存在越界問(wè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; 
            }
            好笨的方法...
            很沒(méi)效率

            (2)
            用強(qiáng)制轉(zhuǎn)換吧, (int)0x*,
            *是什么, 0x7fffffff
            惡心-_-||, 我一開(kāi)始又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)方法..
            //直接貼過(guò)來(lái)了
            //前面有說(shuō)明說(shuō)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 }



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

            Copyright © 藍(lán)塵

            久久精品国产亚洲AV香蕉| 久久婷婷五月综合国产尤物app | 99久久精品国产高清一区二区 | 中文字幕人妻色偷偷久久| 精品久久久久久成人AV| 久久久网中文字幕| 亚洲精品乱码久久久久久久久久久久| 精品蜜臀久久久久99网站| 久久久精品午夜免费不卡| 久久99精品久久久大学生| 久久99国产精品99久久| 国色天香久久久久久久小说| 国产精品久久99| 久久人做人爽一区二区三区| 香蕉久久夜色精品国产小说| 久久ZYZ资源站无码中文动漫| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 久久久久久久国产免费看| 国产精品美女久久久| 亚洲精品乱码久久久久久蜜桃| 久久久久久亚洲Av无码精品专口| 久久久久亚洲AV无码专区网站 | 久久精品国产半推半就| 久久综合色老色| 久久精品国产福利国产琪琪| 久久综合精品国产二区无码| 欧美一区二区三区久久综合| 久久人人爽人人爽AV片| 久久er热视频在这里精品| 综合人妻久久一区二区精品| 亚洲AⅤ优女AV综合久久久| | 国产产无码乱码精品久久鸭| 四虎国产精品免费久久| 久久精品国产精品亚洲| 亚洲综合久久综合激情久久| 国产99精品久久| 热re99久久精品国产99热| 色噜噜狠狠先锋影音久久| 久久精品成人免费看| 国产精品一区二区久久精品无码|