鱼C论坛

 找回密码
 立即注册
查看: 4315|回复: 10

程序不知道出了什么问题

[复制链接]
发表于 2013-10-5 14:09:31 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
include <stdio.h>

long factorial(int n);

void main()
{
    long s;
    int n;

    scanf("%d",&n);
   
    s=factorial(n);
    printf("%ld\n",s);
}

long factorial(int n)
{
   
    long p;
    do
    {
        p = factorial(n-1) * n;
    }
    while(n-1<=0);
   
    return p;
}
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2013-10-5 14:14:43 | 显示全部楼层
本帖最后由 牡丹花下死做鬼 于 2013-10-5 14:23 编辑
  1. //include <stdio.h>
  2. #include<stdio.h>//漏了#

  3. long factorial(int n);

  4. void main()
  5. {
  6.     long s;
  7.     int n;

  8.     scanf("%d",&n);
  9.    
  10.     s=factorial(n);
  11.     printf("%ld\n",s);
  12. }

  13. long factorial(int n)
  14. {
  15.    
  16.     long p;
  17.     do
  18.     {
  19.         p = factorial(n-1) * n;
  20.     }
  21.     while(n-1<=0);
  22.    
  23.     return p;
  24. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2013-10-5 14:25:46 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-10-5 14:31:53 | 显示全部楼层
小兵 发表于 2013-10-5 14:25
我加上了#号,但是运行时不能运算出希望的结果,我输入一个数字时只能打印出数字本身,不能递归运算出阶乘 ...
  1. //include <stdio.h>
  2. #include<stdio.h>//漏了#

  3. long factorial(int n);

  4. void main()
  5. {
  6.     long s;
  7.     int n;

  8.     scanf("%d",&n);
  9.    
  10.     s=factorial(n);
  11.     printf("%ld\n",s);
  12. }

  13. long factorial(int n)
  14. {
  15.    
  16.     long p;
  17.        
  18.         if(n > 1)
  19.         {
  20.                 p = factorial(n-1) * n;
  21.                
  22.         }
  23.         else
  24.         {
  25.                 return 1;
  26.         }
  27.         return p;
  28. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-10-5 14:36:19 | 显示全部楼层
long factorial(int n)
{
   
    if(n==0||n==1)
                return 1;
        else
                return factorial(n-1)*n;
}
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2013-10-5 14:38:58 | 显示全部楼层
我明白用if语句可以实现,现在我想通过while语句完成循环,但是出现了问题,所以就不知道症结在什么地方了?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2013-10-5 14:39:51 | 显示全部楼层
tsembrace 发表于 2013-10-5 14:36
long factorial(int n)
{
   

我明白用if语句可以实现,现在我想通过while语句完成循环,但是出现了问题,所以就不知道症结在什么地方了?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-10-5 14:50:08 | 显示全部楼层
小兵 发表于 2013-10-5 14:38
我明白用if语句可以实现,现在我想通过while语句完成循环,但是出现了问题,所以就不知道症结在什么地方了? ...

你这么写就是死循环啊 n的值是不会变的呀
谁写递归用循环啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-10-5 14:54:56 | 显示全部楼层
n-1完了后 还需要返回 n 。 然后再循环n-1。。。 然后再阶乘完 在返回n-1 无线循环
不知道我说的对不对 应该是这个意思 新手!!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2013-10-5 14:55:29 | 显示全部楼层
牡丹花下死做鬼 发表于 2013-10-5 14:50
你这么写就是死循环啊 n的值是不会变的呀
谁写递归用循环啊

哦,明白了,谢谢指点!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-10-5 18:07:09 | 显示全部楼层
小兵 发表于 2013-10-5 14:39
我明白用if语句可以实现,现在我想通过while语句完成循环,但是出现了问题,所以就不知道症结在什么地方了 ...

问题多了
long factorial(int n)
{
    long p=1;   
    if(n==0)
       return p;
    do{
       p*=n;
     }while(--n>=0);
     return p;
}
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-1 19:19

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表