2201_75843485 2023-01-16 13:40 采纳率: 50%
浏览 39
已结题

C语言,函数,基础题

题目:用递归法求n!。
下面是我的想法

int end(int x)
{
    int z;
    
    z=x*end(x-1);
    return (z);
}
#include<stdio.h>
int main()
{
    int n;
    scanf("%d",&n);
    int end(int x);
    
    printf("n!=%d\n",end(n));
    return 0;
}

但是这个程序运行不了,我找不出错误,有没有人帮忙讲一下,谢谢

  • 写回答

3条回答 默认 最新

  • ShowMeAI 2023-01-16 15:33
    关注

    你的代码存在一些问题。

    • 首先,你的函数end没有设置递归终止条件。这导致函数一直调用自身,直到堆栈溢出。
    • 第二,你在main函数中重新声明了end函数。这是不必要的,而且会导致编译错误。

    下面是更正后的代码,它解决了上述问题。

    #include<stdio.h>
    
    int end(int x){
        int z;
        if (x==1){
            return 1;
        }
        z=x*end(x-1);
        return (z);
    }
    
    int main(){
        int n;
        scanf("%d",&n);
        printf("n!=%d\n",end(n));
        return 0;
    }
    

    这段代码基于递归,当x等于1时返回1,终止递归。否则,将当前的x乘上end(x-1)的结果。这样,在每次递归调用中都会计算出x的阶乘,并返回最终结果。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 1月24日
  • 已采纳回答 1月17日
  • 创建了问题 1月16日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部