开始大部分人会用两个for循环来写计算这一个
int main()
{
int i = 0;
int n = 0;
int sum = 0;
int ret = 1;
for (n = 1; n <= 10; n++)
{
for (i = 1; i <= n; i++)
{
ret = ret * i;
}
sum = sum+ret;
}
printf("%d",sum);
return 0;
}
运行后发现结果和预想的不一样,可以按下F10打开监视窗口查看运行情况,发现ret的值给重复使用了,我们要把ret的值重新赋1
int main()
{
int i = 0;
int n = 0;
int sum = 0;
int ret = 1;
for (n = 1; n <= 10; n++)
{
ret = 1;
for (i = 1; i <= n; i++)
{
ret = ret * i;
}
sum = sum+ret;
}
printf("%d",sum);
return 0;
}
这样运算会很占用内存,可以对其优化,先把阶层的值求出来,再对它进行累加
int main()
{
int n = 0;
int sum = 0;
int ret = 1;
for (n = 1; n <= 10; n++)
{
ret = ret * n;
sum = sum+ret;
}
printf("%d",sum);
return 0;
}