请看一下图片,我是新手,好多东西不会啊,谢谢了
这是道计算n的阶乘的题啊
#include<stdio.h>
main(){
int n,i=1;
long js=1;
scanf("%d",&n);
if(n>=0 && n<=12){
do{
js*=i;
i++;
}while(i<=n);
printf("%ld\n",js);
}
else{
printf("shuruwuxiao\n");
}
}
main(){
int n,i=1;
long js=1;
scanf("%d",&n);
if(n>=0 && n<=12){
do{
js*=i;
i++;
}while(i<=n);
printf("%ld\n",js);
}
else{
printf("shuruwuxiao\n");
}
}
不解释
温馨提示:答案为网友推荐,仅供参考
第1个回答 2015-11-13
#include <stdio.h>
long long f1 (int n)
{
long long sum = 1;
for (int i=1;i<=n;i++)
{
sum*=i;
}
return sum;
}
long long f2 (int n)
{
long long sum =1;
int i=1;
do
{
sum*=i;
i++;
}while(i<=n);
return sum;
}
int main()
{
int n;
scanf("%d",&n);
printf("%lld\n",f1(n));
}
long long f1 (int n)
{
long long sum = 1;
for (int i=1;i<=n;i++)
{
sum*=i;
}
return sum;
}
long long f2 (int n)
{
long long sum =1;
int i=1;
do
{
sum*=i;
i++;
}while(i<=n);
return sum;
}
int main()
{
int n;
scanf("%d",&n);
printf("%lld\n",f1(n));
}
20! long long是存不下的,可以采用数组的形式计算
int sum[10000];一位存一位,或者一位存4位,这样就可以求任意数的阶乘了
第2个回答 2015-11-13
源程序在哪里。。
要不我给你个递归的,你自己改?。。
已调试。
#include <stdio.h>
int factorial(int n)
{
return (n == 1)?n:factorial(n-1)*n;
}
int main(void)
{
int n,fac;
printf("Please input the value of n:");
scanf("%d",&n);
fac = factorial(n);
printf("The result is:%d\n",fac);
return 0;
}
最下面说要用for do..while改写源程序,
递归版的给你了,不贴源程序就自己改吧。
要不我给你个递归的,你自己改?。。
已调试。
#include <stdio.h>
int factorial(int n)
{
return (n == 1)?n:factorial(n-1)*n;
}
int main(void)
{
int n,fac;
printf("Please input the value of n:");
scanf("%d",&n);
fac = factorial(n);
printf("The result is:%d\n",fac);
return 0;
}
最下面说要用for do..while改写源程序,
递归版的给你了,不贴源程序就自己改吧。