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

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

                初看,打印出這些數字,簡單!我們剛學C的時候什么沒打印過啊, 再往下看,不能用循環,不能用條件判斷, 而且只能用一條語句。。。。。
            我們來分析一下困難與可能的解決辦法:
            1.不能用循環,要打印出那么多數字,只有一個辦法了,那就是遞歸
            2.不能用條件判斷,我們知道,遞歸是需要有終止條件的,不然就無窮遞歸了,那么我們需要作條件判斷來終止遞歸,可是那些常用的條件判斷語句又不能用,怎么辦? 看看C中的&&運算符:

            expression1 && expression2;

            只有在Expression為true的情況下,才會繼續執行expression2,這也就相當于條件判斷語句

            if(expression1) expression2;

            好,這兩個問題都有了相應的解決方案,現在要做的就是用你的邏輯把這些語句巧妙的組合起來, 可以說答案是多種多樣的,下面就是一個比較簡單的:

             

            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是在遞歸的時候, 而打印7,6,5,4,3,2,1則是在遞歸回歸的時候, 前一個語句要“或”一下1,就是為了保證后面的打印語句在回歸時能夠執行到。

            可能很多人會覺得這種筆試題沒有什么意義, 因為在實際項目中不可能寫這么tricky的代碼,寫的麻煩,讀的心煩,維護起來亂成一團。。。但是這短短的一句語句,卻是十分考驗人的,對遞歸算法,對C運算符,對邏輯智商都是有著不低的要求。所以,我覺得這是一個好題,好到讓我擔心沒人能在規定時間里做出來:)
            posted on 2007-08-04 22:13 SmartPtr 閱讀(1754) 評論(15)  編輯 收藏 引用

            FeedBack:
            # re: 一條語句中的邏輯
            2007-08-04 22:42 | pass86
            遞歸的就是能簡化過程,但是,我們常常用迭代來消除遞歸。遞歸是個省事的好方法。  回復  更多評論
              
            # re: 一條語句中的邏輯
            2007-08-05 15:22 | windywinter
            ……函數中唯一能夠調用的函數就是printf。
            允許遞歸調用p嗎?
              回復  更多評論
              
            # re: 一條語句中的邏輯
            2007-08-05 17:09 | SmartPtr
            我想題意應該就是允許遞歸調用,不然難度貌似很高的  回復  更多評論
              
            # re: 一條語句中的邏輯
            2007-08-05 17:16 | pass86
            這個技巧很COOL,贊一個。  回復  更多評論
              
            # re: 一條語句中的邏輯
            2007-08-05 17:56 | windywinter
            很納悶,c沒有短路求值嗎?  回復  更多評論
              
            # re: 一條語句中的邏輯
            2007-08-06 00:40 | To Be C++
            我想如果是面試的時候我可能會答不上來 因為本人面試的時候比較容易緊張  回復  更多評論
              
            # re: 一條語句中的邏輯
            2007-08-06 08:31 | SmartPtr
            @windywinter

            expression1 && expression2;
            只有在Expression為true的情況下,才會繼續執行expression2,這也就相當于條件判斷語句
            if(expression1) expression2;


            這就是利用了其短路求值的功能  回復  更多評論
              
            # re: 一條語句中的邏輯
            2007-08-07 20:02 | 羅賓李
            不錯的題目  回復  更多評論
              
            # re: 一條語句中的邏輯
            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分.  回復  更多評論
              
            # re: 一條語句中的邏輯
            2007-08-09 14:38 | pass86
            @ken
            轉換迭代。  回復  更多評論
              
            # re: 一條語句中的邏輯
            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 一下,^_^。  回復  更多評論
              
            # re: 一條語句中的邏輯
            2007-08-12 15:12 | wonxlei
            相當不錯啊~
            確實如你所說:十分驗人呢~  回復  更多評論
              
            # re: 一條語句中的邏輯
            2007-08-13 16:11 | zenith
            有點意思!  回復  更多評論
              
            # re: 一條語句中的邏輯
            2008-07-07 12:25 | 士大夫
            ( ( ( (i <= n) && (printf("%d\n",i) ) ) && ( p(i+1, n) ) ) ) && ( (i < n) && ( printf("%d\n", i) ) ) ;

            這個也可以  回復  更多評論
              
            # re: 一條語句中的邏輯
            2008-12-17 07:05 | wsy
            考的是簡單指令集如何實現復雜功能
            類似于匯編……  回復  更多評論
              
            亚洲AV伊人久久青青草原| 久久精品夜色噜噜亚洲A∨| 东方aⅴ免费观看久久av| 亚洲AV无码久久精品色欲| 久久久久久久久久久久中文字幕 | 久久久国产精品亚洲一区| 久久久亚洲欧洲日产国码二区 | 欧美午夜A∨大片久久 | 蜜臀久久99精品久久久久久| 久久综合久久综合亚洲| 无码人妻少妇久久中文字幕蜜桃| 97久久精品午夜一区二区| 久久久久99精品成人片| 久久免费的精品国产V∧| 香蕉久久影院| 久久国产成人午夜aⅴ影院| 国产精品久久久久久五月尺| 久久线看观看精品香蕉国产| A级毛片无码久久精品免费| 久久久久亚洲精品天堂久久久久久 | 久久国产综合精品五月天| 久久婷婷激情综合色综合俺也去| 亚洲精品国产成人99久久| 亚洲精品乱码久久久久久 | 亚洲成色999久久网站| 色妞色综合久久夜夜| 香蕉久久AⅤ一区二区三区| 91久久精品电影| 狠狠狠色丁香婷婷综合久久俺| 久久天天躁狠狠躁夜夜躁2014| 国产福利电影一区二区三区久久久久成人精品综合 | 久久亚洲精品视频| 亚洲成色www久久网站夜月| 久久久国产99久久国产一| 久久久久无码国产精品不卡| 99久久国产亚洲高清观看2024| 天天久久狠狠色综合| 久久99国产精品久久久| 久久91精品国产91久久小草| 国产成人精品久久免费动漫| 69久久夜色精品国产69|