标题:算的数不对呢?
只看楼主
sneeze
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2006-2-24
 问题点数:0 回复次数:8 
算的数不对呢?

#include <stdio.h>

prod();

main()
{int n=0;
scanf("%d",&n);
printf("%d",prod(n));
}

prod(int c)
{ int y;
if (c<1) return (1);
y=c*prod(--c);
return y;
}

搜索更多相关主题的帖子: include return 
2006-02-28 17:32
ヤ順祺冄繎ヤ
Rank: 8Rank: 8
等 级:贵宾
威 望:42
帖 子:3032
专家分:0
注 册:2005-11-9
得分:0 
不懂,,,什么不对?
2006-02-28 17:41
chenfeiam
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2006-2-16
得分:0 

如果是if (c<1), y=c*prod(--c);那么这个嵌套最后当C=1时,--C为0,所以结果都是0啦,
另外y=c*prod(--c);()的优先级最高,先计算,那么C的值实际上已经被减了1。
#include <stdio.h>

int prod(int c);

main()
{int n=0;
scanf("%d",&n);
printf("%d",prod(n));
}

int prod(int c)
{ int y;
if (c<=1) return (1);
y=(c+1)*prod(--c);
return y;
}
这样应该可以。


2006-02-28 17:53
ヤ順祺冄繎ヤ
Rank: 8Rank: 8
等 级:贵宾
威 望:42
帖 子:3032
专家分:0
注 册:2005-11-9
得分:0 
懂了...原来是递归哟..刚才还没注意看呢..
2006-02-28 18:09
sneeze
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2006-2-24
得分:0 

谢谢啦,果然是高手亚!

2006-02-28 21:51
tomic
Rank: 1
等 级:新手上路
帖 子:45
专家分:0
注 册:2005-11-17
得分:0 
递归是怎么做的啊?就是上面这个程序的执行过程.
2006-02-28 21:53
zhangjuan
Rank: 1
等 级:新手上路
帖 子:992
专家分:0
注 册:2006-1-19
得分:0 
以下是引用chenfeiam在2006-2-28 17:53:00的发言:

如果是if (c<1), y=c*prod(--c);那么这个嵌套最后当C=1时,--C为0,所以结果都是0啦,
另外y=c*prod(--c);()的优先级最高,先计算,那么C的值实际上已经被减了1。
#include <stdio.h>

int prod(int c);

main()
{int n=0;
scanf("%d",&n);
printf("%d",prod(n));
}

int prod(int c)
{ int y;
if (c<=1) return (1);
y=(c+1)*prod(--c);
return y;
}
这样应该可以。

我觉得你的方法行不通,(c+1)是c的下一个数,而--c是c的上一个数,而c的值的未用到。


2006-03-03 09:19
zhangjuan
Rank: 1
等 级:新手上路
帖 子:992
专家分:0
注 册:2006-1-19
得分:0 

#include <stdio.h>

int prod(int c);

main()
{int n=0;
scanf("%d",&n);
printf("%d",prod(n));
}

int prod(int c)
{ int y;
while((--c)!=0 && c>=1)
{y=c*prod(--c);
return y;
}
return 1;/*负数和零未考虑*/
}


2006-03-03 09:28
zhengwen
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2006-3-4
得分:0 

#include <stdio.h>

int prod(int c);

main()
{int n=0;
scanf("%d",&n);
printf("%d",prod(n));
}

int prod(int c)
{ int y;
if (c<=1) return (1);
c--;
y=(c+1)*prod(c);
return y;
}
//建议楼主以后声明函数时最好不要省略声明类型
//递归的时候先是回归,然后再递推,只要得到了一个确切的值它就会递推,所以不必考虑负数的情况

2006-03-04 09:26



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-47674-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.094842 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved