免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: weckay
打印 上一主题 下一主题

[函数] EMC小有难度的笔试,撰写仅有一行的语句的函数??? [复制链接]

论坛徽章:
0
111 [报告]
发表于 2008-07-25 11:50 |只看该作者
超强

论坛徽章:
0
112 [报告]
发表于 2008-10-04 11:39 |只看该作者

回复 #10 Edengundam 的帖子

return 后面的 +1 是什么意思啊
为什么要 +1 呢

论坛徽章:
0
113 [报告]
发表于 2008-10-04 16:14 |只看该作者
我是来盖楼学习的。。。

论坛徽章:
0
114 [报告]
发表于 2008-10-04 20:15 |只看该作者
很久前的了
int t(int n){
    return n==1?printf("%d",n):t(n-1)&&printf("%d",n)&&t(n-1);
}

论坛徽章:
0
115 [报告]
发表于 2008-10-07 15:40 |只看该作者
int p(int i,int N)
{
    return ( printf( "%d\n", i ) && N > i && p( i+1, N ) && printf( "%d\n", i ) ) + 1;
}

linux ,gcc

论坛徽章:
0
116 [报告]
发表于 2008-10-07 15:46 |只看该作者
原帖由 jeff1115 于 2008-10-4 11:39 发表
return 后面的 +1 是什么意思啊
为什么要 +1 呢

你把+1去了试试,那样的话只能打印一半值,如果去了+1,return后的表达式的值在i=N时候为0,在递归调用时候函数值为0则后面的printf函数不执行,所有只能打印一半了。。。。不知道说清楚了没

论坛徽章:
0
117 [报告]
发表于 2008-10-07 21:41 |只看该作者
如此好贴,不顶 不行。。
学习了。。。

论坛徽章:
0
118 [报告]
发表于 2008-10-08 21:22 |只看该作者
原帖由 flw 于 2007-4-2 15:42 发表
稍微简化了一下:
int p( int i, int N ){
    return ( printf( "%d\n", i ) && N > 1 && p( i+1, N-1 ) && printf( "%d\n", i ) ) + 1;
}

to 6 楼:你那个也可以简化的。


对flw大侠的代码做了拆分,看起来容易一些,顺便对那些给出答案的大牛们表达一下我滔滔江水一样的崇拜:


  1. int p(int i, int N)
  2. {
  3.         if ( N >1)
  4.         {
  5.                 printf( "%d\n", i );
  6.                 return p( i+1, N-1 ) && printf( "%d\n", i );
  7.         }
  8.         else
  9.         {
  10.                 return  1;
  11.         }
  12. }
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP