2201_75843485 2023-02-25 09:23 采纳率: 52.2%
浏览 19
已结题

C语言 函数的循环和递归 基础题

用的vs2010编译器,代码运行了一半出现这个窗口是什么意思

img

题目是用循环的方法和递归法算n的阶乘
我的代码:

#include<stdio.h>//n的阶乘//

int xh(int );
int dg(int );

int main()
{
    int a;
    scanf("%d",&a);
    printf("循环算法%d的阶乘=%d\n",a,xh(a));
    printf("递归算法%d的阶乘=%d\n",a,dg(a));
    return 0;
}

int xh(int n)
{
    int m=1;
    while(n>0)
    {
        
        m=m*n;
        n--;
    }
    return m;
}

int dg(int n)
{
    int m;
    if(n>0)
    {
        
        m=n*dg(n-1);
    }
    return m;
}

谢谢

  • 写回答

3条回答 默认 最新

  • MarkHan_ 2023-02-25 09:33
    关注

    该回答引用GPTᴼᴾᴱᴺᴬᴵ
    你的递归函数 dg 中没有设置 n=0 的结束条件,导致递归一直进行下去,出现了编译错误。
    可以将递归函数改为:

    int dg(int n)
    {
        if (n == 0) {
            return 1;
        } else {
            return n * dg(n-1);
        }
    }
    

    这样当 n=0 时递归会结束,并返回1作为终止条件。

    另外,你的循环函数 xh 代码逻辑是正确的,但是在 main 函数中输入一个较大的数,比如 20,程序可能会输出错误的结果,因为 int 类型最大只能表示到 2^31-1,超过这个数值会出现溢出的情况。如果需要计算更大的数的阶乘,可以考虑使用高精度数库。

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

报告相同问题?

问题事件

  • 系统已结题 3月5日
  • 已采纳回答 2月25日
  • 创建了问题 2月25日

悬赏问题

  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么