解题思路:这里主要先分析阶乘求和,主要有两个步骤:第一个步骤是从n递减相乘,再将n-1重新循环再递减相乘,直到n=1;
这部分代码如下:
for (a = n; a >= 1; a--) { //这里用n--,将n-1代入循环
c=1; //如果不把c值每次初始化为1,则下一次b循环会将上一次循环的c值代入运算,导致结果变得很大,结果错误
for (b = a; b >= 1; b--) {
c = b * c; //递减相乘
}
第二步将所有积相加赋值给变量sn
sn = sn + c; //这部分代码是在第一个for循环里
注意事项:第一次设置了int 型,,会显示答案错误,要设置long long int 型变量就能通过
参考代码:
#include<stdio.h>
int main() {
long long int a, b, c, n,sn; //int 型变量会报错,要用long long int 型变量,如果a,b,c,n单独设置成int型会报错
a = b =sn= 0;
scanf("%lld", &n); //这里可以用%lld也可以用%d
for (a = n; a >= 1; a--) {
c=1; //如果不把c值每次初始化为1,则下一次b循环会将上一次循环的c值代入运算,导致结果变得很大,结果错误
for (b = a; b >= 1; b--) {
c = b * c;
}
sn = sn + c;
}
printf("%lld", sn); //这里要跟long long int 型变量匹配,用%lld
return 0;
}
0.0分
0 人评分