A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© P@sser-by 中级黑马   /  2015-3-9 12:31  /  1058 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

/*
改错题:
用递归方法求n的阶乘。
*/
#include<stdio.h>
int mul(int m);
int main()
{
    int n = 0;
    while (n <= 0)
    {
        printf("请输入一个正整数:\n");
        scanf("%d",&n);
    }
    printf("%d的阶乘结果是:%d\n",n,mul(n));
       return 0;
}
int mul(int m)
{
    int p;
    p = m*mul(m-1);
    return p;
}



QQ图片20150309122030.jpg (17.67 KB, 下载次数: 21)

QQ图片20150309122030.jpg

4 个回复

倒序浏览
  1. #include<stdio.h>
  2. int mul(int m);
  3. int main()
  4. {
  5.     int n = 0;
  6.     while (n <= 0)
  7.     {
  8.         printf("请输入一个正整数:\n");
  9.         scanf("%d", &n);
  10.     }
  11.     printf("%d的阶乘结果是:%d\n", n, mul(n));
  12.     return 0;
  13. }
  14. int mul(int m)
  15. {
  16.         if (0 == m)
  17.                 return 1;
  18.     return m * mul(m-1);
  19. }
复制代码
回复 使用道具 举报

Yes,you are right !
回复 使用道具 举报
楼上可用
回复 使用道具 举报
缺少递归函数的出口。
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马