
//计算n的阶乘
int main()
{
int i = 0;
int n = 0;
int ret = 1;
scanf("%d", &n);
for (i = 1; i <= n; i++)
{
ret = ret * i;
}
printf("%d ", ret);
return 0;
}
求解1的阶乘到n的阶乘之和
这是较为复杂的方法,也是最早想到的方法。
//1的阶乘到n的阶乘的和
int main()
{
int i = 0;
int n = 0;
scanf("%d", &n);
int sum = 0;
int ret = 1;
for (i = 1; i <= n; i++)
{
ret = 1;//每次ret重置为一
int j = 0;
for (j = 1; j <= i; j++)
{
ret = ret * j;
}
sum = sum + ret;
}
printf("%d\n", sum);
return 0;
}
这是这类题目一种更简单的做法。
//求1阶乘到n阶乘的简化法
int main()
{
int i = 0;
int n = 0;
scanf("%d", &n);
int sum = 0;
int ret = 1;
for (i = 1; i <= n; i++)
{
ret = ret * i ;
sum = sum + ret;
}
printf("%d\n", sum);
return 0;
}欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)