#include
"stdio.h"
main()
{
int
n,i
double
p=1//这里用的是Double,不用Int,因为Int范围太小
printf("请输入一个数字:")
scanf("%d",&n)
for(i=2i<=ni++)
p*=i
printf("n!shu=%lf\n",p)
}
扩展资料:
用Ruby求 365 的阶乘。
def AskFactorial(num) factorial=1
step(num,1){|i| factorial*=i}
return factorial end factorial=AskFactorial(365)
puts factorial
阶乘有关公式
该公式常用来计算与阶乘有关的各种极限。
此为斯特林公式的简化公式。
参考资料来源:百度百科-阶乘
所谓n的阶乘就是从1到n的累积,所以可以通过一个for循环,从1到n依次求积即可。
参考代码:
#include "stdio.h"
int main() {
int n,i,s=1。
scanf("%d",&n)。
for(i=1i<=ni++)//for循环求累积。
s=s*i。
printf("%d\n",s)。
return 0。
注意事项:
1、任何大于1的自然数n阶乘表示方法:n!=1×2×3×……×n 或 n!=n×(n-1)。
2、n的双阶乘:当n为奇数时表示不大于n的所有奇数的乘积。
如:7!=1×3×5×7。
3、当n为偶数时表示不大于n的所有偶数的乘积。
如:8!=2×4×6×8。
4、小于0的整数-n 的阶乘表示:
(-n)!= 1 / (n+1)。
5、0的阶乘:0!=0。
6、组合数公式。