factrl.cpp
来自「C++数值算法原书代码」· C++ 代码 · 共 19 行
CPP
19 行
#include <cmath>
#include "nr.h"
using namespace std;
DP NR::factrl(const int n)
{
static int ntop=4;
static DP a[33]={1.0,1.0,2.0,6.0,24.0};
int j;
if (n < 0) nrerror("Negative factorial in routine factrl");
if (n > 32) return exp(gammln(n+1.0));
while (ntop<n) {
j=ntop++;
a[ntop]=a[j]*ntop;
}
return a[n];
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?