• <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>
            隨筆 - 8, 文章 - 0, 評(píng)論 - 17, 引用 - 0
            數(shù)據(jù)加載中……

            求兩個(gè)數(shù)中最大值,不用判斷語(yǔ)句。

             

            #include "iostream.h" 
            #include 
            "math.h" 

            #define bits ( sizeof( int ) * 8 - 1 ) 
            static int CheckFlag( int x, int y )  
            {  
            int s1 = x >> bits;  
            int s2 = y >> bits;  
            s1
            =abs(s1); 
            s2
            =abs(s2); 
            return ( s1 * 2 + s2 );  
            }  
            static int SameSign( int Flag, int x, int y ) 
            {  
            int t[2= { x, y }; 
            long z = x - y; 
            int s = z >> (bits+32);  
            s
            =abs(s); 
            return t[s]; 
            }  
            static int DiffSign(int Flag,int x,int y) 比較 
            {  
            int t[2= { x, y };  
            return t[Flag - 1]; 

            static int (*FuncList[4])(int Flag,int x,int y)={SameSign, DiffSign, DiffSign, SameSign};  
            static int Max( int x, int y )  
            {  
            int Flag = CheckFlag( x, y );  

            return (*FuncList[Flag])(Flag,x,y);  

            void main()  

            int x,y,z; 
            cout
            <<"請(qǐng)輸入整型x的值(-32768~32767):"
            cin
            >>x; 
            cout
            <<"請(qǐng)輸入整型y的值(-32768~32767):"
            cin
            >>y; 
            z
            =Max(x,y); 
            cout
            <<"最大的數(shù):"<<z<<endl; 
            }  



            #define bits ( sizeof( int ) * 8 - 1 ) //移動(dòng)的位數(shù)
            static int SameSign( int Flag, int x, int y ) //函數(shù)功能:x,y同號(hào)時(shí)的比較
            static int DiffSign(int Flag,int x,int y) //函數(shù)功能:x,y異號(hào)時(shí)的比較
            static int (*FuncList[4])(int Flag,int x,int y)={SameSign, DiffSign, DiffSign, SameSign}; //定義函數(shù)指針數(shù)組
            static int Max( int x, int y ) //函數(shù)功能:求最大值

            static int CheckFlag( int x, int y ) //函數(shù)功能:檢測(cè)x,y的符號(hào)
            /*
            Flag 的值
            + +:0
            - +;1
            + 1:2
            - -:3
            */

            posted on 2008-08-21 14:20 YG 閱讀(3192) 評(píng)論(11)  編輯 收藏 引用 所屬分類: C/C++ & 設(shè)計(jì)模型

            評(píng)論

            # re: 求兩個(gè)數(shù)中最大值,不用判斷語(yǔ)句。  回復(fù)  更多評(píng)論   

            abs怎么實(shí)現(xiàn)?還不是用判斷了

            那直接(a+b+abs(a-b))/2不就得了?
            2008-08-21 15:37 | Etrnls

            # re: 求兩個(gè)數(shù)中最大值,不用判斷語(yǔ)句。  回復(fù)  更多評(píng)論   

            樓上說(shuō)得對(duì),沒(méi)意思
            2008-08-21 16:13 | ghbxx2004

            # re: 求兩個(gè)數(shù)中最大值,不用判斷語(yǔ)句。  回復(fù)  更多評(píng)論   

            int max(int a, int b)
            {
            int diff = b - a;
            return b - (diff & (diff >> 31));
            }
            2008-08-21 17:00 | fish_autumn

            # re: 求兩個(gè)數(shù)中最大值,不用判斷語(yǔ)句。  回復(fù)  更多評(píng)論   

            int max(int x,int y)
            {
            int buf[2]={x,y};
            unsigned int z;

            z=x-y;
            z = z>>31;

            return buf[z];
            }
            值得注意的是右移運(yùn)算.對(duì)于有符號(hào)數(shù),在右移時(shí),符號(hào)位將隨同移動(dòng).當(dāng)為正數(shù)時(shí),最高位補(bǔ)0,而為負(fù)數(shù)時(shí),符號(hào)位為1.
            x-y后如果是負(fù)數(shù),則z>>31后,為1,buf[1]=y,否則同樣分析,buf[0]=x
            2008-08-21 17:18 |

            # re: 求兩個(gè)數(shù)中最大值,不用判斷語(yǔ)句。  回復(fù)  更多評(píng)論   

            感覺(jué)剛學(xué)編程的樣子.
            性價(jià)比低呀
            2008-08-22 06:07 | 4h

            # re: 求兩個(gè)數(shù)中最大值,不用判斷語(yǔ)句。  回復(fù)  更多評(píng)論   

            有創(chuàng)意的哈,不過(guò)工程中不要有這種。
            2008-08-22 09:12 | cexer

            # re: 求兩個(gè)數(shù)中最大值,不用判斷語(yǔ)句。  回復(fù)  更多評(píng)論   

            低手出的面試題吧?
            2008-08-23 04:11 | 地方

            # re: 求兩個(gè)數(shù)中最大值,不用判斷語(yǔ)句。  回復(fù)  更多評(píng)論   

            用微操作來(lái)求兩個(gè)數(shù)中最大值,的確很有趣。
            2008-08-24 15:48 | 戴爾筆記本

            # re: 求兩個(gè)數(shù)中最大值,不用判斷語(yǔ)句。[未登錄](méi)  回復(fù)  更多評(píng)論   

            囧,倆int比較就是減了之后看符號(hào)位而已……何必呢
            2008-08-25 10:12 | 陳梓瀚(vczh)

            # re: 求兩個(gè)數(shù)中最大值,不用判斷語(yǔ)句。  回復(fù)  更多評(píng)論   

            謝謝,各位的厚愛(ài),這篇是以前再學(xué)校時(shí)期發(fā)過(guò)的帖子,
            覺(jué)得很有趣所以就發(fā)出來(lái),額外可以得到各路英雄的評(píng)價(jià)值得,哈哈。
            2008-08-26 11:11 | YG

            # re: 求兩個(gè)數(shù)中最大值,不用判斷語(yǔ)句。  回復(fù)  更多評(píng)論   

            abs也不是非要用比較啊 :)
            2008-09-12 00:38 | sdfasf
            久久人人爽人人爽AV片| 亚洲成色WWW久久网站| 亚洲?V乱码久久精品蜜桃| 漂亮人妻被中出中文字幕久久 | 热久久这里只有精品| 亚洲国产美女精品久久久久∴| 93精91精品国产综合久久香蕉| 青青青青久久精品国产h久久精品五福影院1421 | 日产精品久久久久久久| 久久香蕉综合色一综合色88| 亚洲欧美日韩精品久久亚洲区| 激情伊人五月天久久综合| 一级做a爰片久久毛片毛片 | 日本欧美国产精品第一页久久| 新狼窝色AV性久久久久久| 久久免费视频一区| a级成人毛片久久| 久久夜色精品国产噜噜麻豆| 亚洲&#228;v永久无码精品天堂久久 | 精品人妻伦九区久久AAA片69 | 亚洲国产精品高清久久久| 人妻无码精品久久亚瑟影视| 久久久91精品国产一区二区三区 | 久久国产精品一区二区| 人妻无码久久一区二区三区免费| 最新久久免费视频| 伊色综合久久之综合久久| 久久一区二区免费播放| 久久久久久国产精品无码下载| 久久精品国产91久久麻豆自制| 潮喷大喷水系列无码久久精品 | 久久精品国产久精国产思思| 色欲综合久久躁天天躁蜜桃| 狠狠色丁香久久婷婷综合蜜芽五月 | 国产精品无码久久综合网| 久久亚洲国产欧洲精品一| 久久精品中文字幕无码绿巨人| 日韩精品久久无码中文字幕| 久久亚洲日韩精品一区二区三区| 久久亚洲中文字幕精品有坂深雪| 久久夜色精品国产欧美乱|