2301_79861214 2023-10-30 20:52 采纳率: 89.5%
浏览 10
已结题

阶乘计算出了直接计算 还有别的方法吗

img

img


请问阶乘计算还可以怎么计算呢 调用了函数也不行 循环更不行 是有别的公式吗 请各位指点

  • 写回答

2条回答 默认 最新

  • 庞加莱的算法空间 2023-10-30 22:10
    关注

    我理解哈,你的代码主要有两个地方要改进一下。首先阶乘的增长速度是非常快的,10的阶乘大约就是百万量级了。我看你用int m来计算阶乘,这样的话很快就会出现溢出现象了,这个时候m的值就已经不再是正确结果了,甚至可能出现负数的情况。所以,我感觉你可以试试改成double m,然后其他保持不变,看是否可以通过所有测试用例哈。

    另一点就是,即使改成double m,有可能还是不行,因为double能表示的最大值也是有上限的,所以,这里有个算是trick吧,就是不要计算阶乘,而是计算"阶乘分之一",因为"阶乘分之一"即使在小,顶多变成0,而不会出现溢出情况,比如说这样

    
    double m = 1.0;
    for(int i = 1; i <= a; i++){
       m = m / i;
    }
    z = pow(x, a);
    n = z * m;
    

    你先试试是否可行哈,如果不行的话还可以再来讨论

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

报告相同问题?

问题事件

  • 系统已结题 11月9日
  • 已采纳回答 11月1日
  • 创建了问题 10月30日

悬赏问题

  • ¥15 三分类机器学习模型可视化分析
  • ¥15 本地测试网站127.0.0.1 已拒绝连接,如何解决?(标签-ubuntu)
  • ¥50 Qt在release捕获异常并跟踪堆栈(有Demo,跑一下环境再回答)
  • ¥30 python,LLM 文本提炼
  • ¥15 关于将inet引入的相关问题
  • ¥15 关于一个倒计时的操作和显示设计
  • ¥15 提问STK的问题,哪位航天领域的同学会啊
  • ¥15 苹果系统的mac m1芯片的笔记本使用ce修改器使用不了
  • ¥15 单相逆变的电压电流双闭环中进行低通滤波PID算法改进
  • ¥15 关于#java#的问题,请各位专家解答!