QQ登录

只需一步,快速开始

搜索
【活动】边做笔记边学习,还能赢取奖学金!
查看: 64|回复: 2

[已解决]小问题不明白,求助大神!

[复制链接]
累计签到:38 天
连续签到:2 天
最佳答案
0 
发表于 5 天前 | 显示全部楼层 |阅读模式

马上注册加入鱼C,享用更多服务吧^_^

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

x
#include<stdio.h>

long recursion(int n);

void main()
{
        int n;
        long result;

        scanf("%d",&n);
        result=recursion(n);

        printf("%ld\n",result);
}

long recursion(int n)
{
        long k;
        if(n<0)
        {
                printf("input error!\n");
        }
        else if(n==0||n==1)
        {
                k=1;
        }
        else
        {
                k=recursion(n-1)*n;
        }
        return k;
}
为什么要有n==0这个条件?
如果输入0的话,函数返回为1, 0!等于1?
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:28 天
连续签到:1 天
最佳答案
1 
发表于 5 天前 | 显示全部楼层    本楼为最佳答案   
对啊.. 0! = 1.规定的
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:44 天
连续签到:20 天
最佳答案
3 
发表于 5 天前 | 显示全部楼层
阶乘的定义:n! = n * (n-1) * (n-2) * ...* 2 * 1
且 1! = 1, 0! =1
这是为了保证 n! = n * (n-1)! 对于n>=1都成立
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋手机版Archiver( 粤公网安备 44051102000370号 | 粤ICP备11014136号

© 2010-2017 FishC.com GMT+8, 2017-7-22 10:35 Powered by Discuz! X2.5 Theme by dreambred

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