鱼C论坛

 找回密码
 立即注册
查看: 3752|回复: 1

inRange()这个函数如何实现,反迭代为何就能判断阶乘计算结果是否超最大值

[复制链接]
发表于 2019-2-25 00:06:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

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

x
  1. #include <iostream>
  2. #include <climits>

  3. class Factorial
  4. {
  5. public:
  6.     Factorial(unsigned short num);
  7.     unsigned long getFactorial();
  8.     bool inRange();

  9. private:
  10.     unsigned short num;
  11. };

  12. Factorial::Factorial(unsigned short num)
  13. {
  14.     this->num = num;
  15. }

  16. unsigned long Factorial::getFactorial()
  17. {
  18.     unsigned long sum = 1;

  19.     for( int i=1; i <= num; i++ )
  20.     {
  21.         sum *= i;
  22.     }

  23.     return sum;
  24. }

  25. bool Factorial::inRange()
  26. {
  27.     unsigned long max = ULONG_MAX;

  28.     for( int i=num; i >= 1; --i )
  29.     {
  30.         max /= i;
  31.     }

  32.     if( max < 1 )
  33.         return false;
  34.     else
  35.         return true;
  36. }

  37. int main()
  38. {
  39.     unsigned short num = 0;

  40.     std::cout << "请输入一个整数: ";
  41.     std::cin >> num;

  42.     Factorial fac(num);

  43.     if( fac.inRange() )
  44.     {
  45.         std::cout << num << "的阶乘值是" << fac.getFactorial() << "\n\n";
  46.     }
  47.     else
  48.     {
  49.         std::cout << "您所输入的值太大!\n\n";
  50.     }

  51.     return 0;
  52. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-25 20:23:06 | 显示全部楼层
简单的移项啊
max=ulong_max/1/2/3/4/.../num=ulong_max/(1*2*3*..*num)=ulong_max/(num!);
max<1   ==>   ulong_max<num!;
所以溢出
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-17 00:23

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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