⑴ n的阶乘编程怎么写
C语言实现,是最简单的方法:
#include<stdio.h>
void main()
{
int i=0;
int a=1;
int n=0;
printf("请输入一个正整数n\n");
scanf("%d",&n);
do
{
i*=a;
a++;
}
while(a<=n);
printf("%d",n);
}
VB或VBS
Option Explicit
On Error Resume Next
Dim intInputValue
Dim iDim intX
' 忽略数值check
intInputValue = CInt(inputbox("请输入整数n,计算n的阶乘", "n的阶乘"))
intX = 1
For i = 1 To intInputValue Step 1
intX = intX * i
Next
msgbox CStr(intX),,"n的阶乘1"
⑵ C语言中如何编程计算阶乘
常见的有两种:
递归版本:
intFac(intn){
if(n==0)return1;
returnn*Fac(n-1);
}
还有一种是循环版:
intans=1;
for(inti=1;i<=n;i++)ans*=i;
测试方法:
#include<stdio.h>
intFac(intn){
if(n==0)return1;
returnn*Fac(n-1);
}
intmain(){
intn;
while(scanf("%d",&n)!=EOF){
intans=1;
for(inti=1;i<=n;i++)ans*=i;
printf("%d%d ",ans,Fac(n));
}
return0;
}
有个值得注意的地方内:阶乘时,数增大容的很快,在n达到13时就会超过int的范围,此时可以用long long或是 __int64来存储更高精度的值,如果还想存储更高位的,需要用数组来模拟大数相乘。
⑶ C语言,求n阶乘的代码
思路:所谓n的阶乘就是从1到n的累积,所以可以通过一个for循环,从1到n依次求积即可。
#include <stdio.h>
int main()
{
int i, n;
int sum = 1;
printf("请输入n: ");
scanf("%d", &n);
for(i=1; i<=n; i++)
{
sum = sum*i;
}
printf("n的阶乘是%d ", sum);
return 0;
}
定义范围
通常所说的阶乘是定义在自然数范围里的(大多科学计算器只能计算 0~69 的阶乘),小数科学计算器没有阶乘功能,如 0.5!,0.65!,0.777!都是错误的。但是,有时候我们会将Gamma 函数定义为非整数的阶乘,因为当 x 是正整数 n 的时候,Gamma 函数的值是 n-1 的阶乘。
以上内容参考:网络-n!