SmartPtr
本博客已搬至:http://www.cnblogs.com/baiyanhuang/
posts - 29,comments - 176,trackbacks - 0
By SmartPtr(http://www.cppblog.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 阅读(1669) 评论(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
考的是简单指令集如何实现复杂功能
类似于汇编……  回复  更多评论
  

只有注册用户登录后才能发表评论。
【推荐】超50万行VC++源码: 大型组态工控、电力仿真CAD与GIS源码库
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理