• <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>
            SmartPtr
            本博客已搬至:http://www.cnblogs.com/baiyanhuang/
            posts - 29,comments - 176,trackbacks - 0
            By SmartPtr(http://www.shnenglu.com/SmartPtr/)

                今天在網(wǎng)上無(wú)意間看到一道筆試題,初看十分簡(jiǎn)單,再看要求發(fā)現(xiàn)還是比較曲折的:
                
            函數(shù)原形已經(jīng)給出:int p(int i, int n); 
            功能:調(diào)用該函數(shù),打印如下格式的輸出,例p(
            17); 
            1 
            2 
            3 
            4 
            5 
            6 
            7 
            6 
            5 
            4 
            3 
            2 
            1 
            即每行一個(gè)數(shù)字。(注意:N只打印一次) 
            要求: 
            函數(shù)中唯一能夠調(diào)用的函數(shù)就是printf。 
            只使用一條語(yǔ)句,如果你真的不能用一條語(yǔ)句,每增加一條語(yǔ)句扣1分。 
            不準(zhǔn)使用如下的關(guān)鍵字:typedef, 
            enumdowhileforswitchcasebreakcontinuegoto,  
            until, 
            if,  ..具體很多我也忘了,反正能用的不多。 
            不能使用逗號(hào)表達(dá)式和?:表達(dá)式。 
            標(biāo)準(zhǔn):(總分10分) 
            1. 每多一條語(yǔ)句扣1分,即每多一個(gè);就扣1分 
            2. 每使用一次if或?:扣2分  
            3. 每使用一次for,while, swith各扣4分 

                初看,打印出這些數(shù)字,簡(jiǎn)單!我們剛學(xué)C的時(shí)候什么沒(méi)打印過(guò)啊, 再往下看,不能用循環(huán),不能用條件判斷, 而且只能用一條語(yǔ)句。。。。。
            我們來(lái)分析一下困難與可能的解決辦法:
            1.不能用循環(huán),要打印出那么多數(shù)字,只有一個(gè)辦法了,那就是遞歸
            2.不能用條件判斷,我們知道,遞歸是需要有終止條件的,不然就無(wú)窮遞歸了,那么我們需要作條件判斷來(lái)終止遞歸,可是那些常用的條件判斷語(yǔ)句又不能用,怎么辦? 看看C中的&&運(yùn)算符:

            expression1 && expression2;

            只有在Expression為true的情況下,才會(huì)繼續(xù)執(zhí)行expression2,這也就相當(dāng)于條件判斷語(yǔ)句

            if(expression1) expression2;

            好,這兩個(gè)問(wèn)題都有了相應(yīng)的解決方案,現(xiàn)在要做的就是用你的邏輯把這些語(yǔ)句巧妙的組合起來(lái), 可以說(shuō)答案是多種多樣的,下面就是一個(gè)比較簡(jiǎn)單的:

             

            int p(int i, int n)
            {
                return ((i < n && printf("%d\n",i) && p(i+1,n)) || 1&& (printf("%d\n",i));
            }
            打印1,2,3,4,5,6是在遞歸的時(shí)候, 而打印7,6,5,4,3,2,1則是在遞歸回歸的時(shí)候, 前一個(gè)語(yǔ)句要“或”一下1,就是為了保證后面的打印語(yǔ)句在回歸時(shí)能夠執(zhí)行到。

            可能很多人會(huì)覺(jué)得這種筆試題沒(méi)有什么意義, 因?yàn)樵趯?shí)際項(xiàng)目中不可能寫(xiě)這么tricky的代碼,寫(xiě)的麻煩,讀的心煩,維護(hù)起來(lái)亂成一團(tuán)。。。但是這短短的一句語(yǔ)句,卻是十分考驗(yàn)人的,對(duì)遞歸算法,對(duì)C運(yùn)算符,對(duì)邏輯智商都是有著不低的要求。所以,我覺(jué)得這是一個(gè)好題,好到讓我擔(dān)心沒(méi)人能在規(guī)定時(shí)間里做出來(lái):)
            posted on 2007-08-04 22:13 SmartPtr 閱讀(1764) 評(píng)論(15)  編輯 收藏 引用

            FeedBack:
            # re: 一條語(yǔ)句中的邏輯
            2007-08-04 22:42 | pass86
            遞歸的就是能簡(jiǎn)化過(guò)程,但是,我們常常用迭代來(lái)消除遞歸。遞歸是個(gè)省事的好方法。  回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2007-08-05 15:22 | windywinter
            ……函數(shù)中唯一能夠調(diào)用的函數(shù)就是printf。
            允許遞歸調(diào)用p嗎?
              回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2007-08-05 17:09 | SmartPtr
            我想題意應(yīng)該就是允許遞歸調(diào)用,不然難度貌似很高的  回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2007-08-05 17:16 | pass86
            這個(gè)技巧很COOL,贊一個(gè)。  回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2007-08-05 17:56 | windywinter
            很納悶,c沒(méi)有短路求值嗎?  回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2007-08-06 00:40 | To Be C++
            我想如果是面試的時(shí)候我可能會(huì)答不上來(lái) 因?yàn)楸救嗣嬖嚨臅r(shí)候比較容易緊張  回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2007-08-06 08:31 | SmartPtr
            @windywinter

            expression1 && expression2;
            只有在Expression為true的情況下,才會(huì)繼續(xù)執(zhí)行expression2,這也就相當(dāng)于條件判斷語(yǔ)句
            if(expression1) expression2;


            這就是利用了其短路求值的功能  回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2007-08-07 20:02 | 羅賓李
            不錯(cuò)的題目  回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2007-08-09 14:31 | ken
            int p (int i, int n)
            {
            for (int k = i, t = i; k <= n*2-i; k++, t -= (k>n)*2-1) printf ("%d\n", t);
            }
            使用遞歸扣5分.  回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2007-08-09 14:38 | pass86
            @ken
            轉(zhuǎn)換迭代。  回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2007-08-11 15:57 | flyman
            bool fun(int i, int n)
            {

            printf("%d\n",i);
            ((i^n)!=0)&&(fun(i+1,n))&&printf("%d\n",i);
            return (i^(n+1))!=0;
            }

            copy 一下,^_^。  回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2007-08-12 15:12 | wonxlei
            相當(dāng)不錯(cuò)啊~
            確實(shí)如你所說(shuō):十分驗(yàn)人呢~  回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2007-08-13 16:11 | zenith
            有點(diǎn)意思!  回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2008-07-07 12:25 | 士大夫
            ( ( ( (i <= n) && (printf("%d\n",i) ) ) && ( p(i+1, n) ) ) ) && ( (i < n) && ( printf("%d\n", i) ) ) ;

            這個(gè)也可以  回復(fù)  更多評(píng)論
              
            # re: 一條語(yǔ)句中的邏輯
            2008-12-17 07:05 | wsy
            考的是簡(jiǎn)單指令集如何實(shí)現(xiàn)復(fù)雜功能
            類似于匯編……  回復(fù)  更多評(píng)論
              

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            国产AV影片久久久久久| a级毛片无码兔费真人久久| 青青草原综合久久大伊人| 久久精品国产亚洲av麻豆图片| 丁香色欲久久久久久综合网| 99久久99这里只有免费费精品| 久久亚洲国产精品一区二区| 香蕉久久永久视频| 韩国无遮挡三级久久| 久久夜色精品国产亚洲| 亚洲精品国产成人99久久| 久久乐国产综合亚洲精品| 亚洲精品国产成人99久久| 久久婷婷五月综合97色直播| 女人香蕉久久**毛片精品| 伊人久久大香线蕉av不卡 | 国产亚洲精品久久久久秋霞| 久久精品人人做人人妻人人玩| 久久久人妻精品无码一区| 91精品国产乱码久久久久久| 99久久国产宗和精品1上映 | 老男人久久青草av高清| 91精品国产91久久久久久| 久久午夜无码鲁丝片| 国产精品亚洲综合久久| 亚洲欧美一级久久精品| 久久久久亚洲AV无码专区桃色| 久久九九亚洲精品| 国产精品青草久久久久婷婷 | 国内精品九九久久久精品| 青青草原综合久久大伊人| 亚洲国产成人久久综合野外| 久久精品无码免费不卡| 亚洲伊人久久大香线蕉苏妲己| 好久久免费视频高清| 91久久成人免费| 久久精品国产WWW456C0M| 久久久久99精品成人片| 久久久久亚洲爆乳少妇无| 污污内射久久一区二区欧美日韩| 人妻系列无码专区久久五月天|