原题链接:[编程入门]阶乘求和
解题思路:
利用双层for循环嵌套,外层模拟每个阶乘数的累加,内层模拟每个数的阶乘,每次求出部分阶乘的结果,并加
入总结果中
注意事项:
本题输入变量的数据范围是20以内,大家可以试验实验输入19,会发现输出了一个负数,说明结果的大小超出
了int类的储存范围,故需要用long long类的变量来储存部分结果和总结果。
参考代码:
#include<iostream>
using namespace std ;
int main()
{
long long sn = 0 ;//总结果
int n ;//输入
cin>>n ;
long long sum = 1 ;//部分阶乘结果
for(int i = 1;i <= n;i++)//每个阶乘数的累加
{
for(int j = 1;j <= i;j++)//阶乘内部计算
{
sum *= j ;
}
sn += sum ;//将每部分阶乘的计算结果加入总结果
sum = 1 ;//回溯,初始化,方便储存下次循环的部分结果
}
cout<<sn<<endl ;//输出结果
return 0 ;
}0.0分
50 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
#include<iostream> using namespace std; int sn(int n); int main() { int a,temp=0; cout << "数入一个不超过20的数:"; cin >> a; for (int ac =1;ac<=a;ac++) { temp += sn(ac); } cout << temp; return 0; } int sn(int n ) { if (n == 0 || n ==1) return 1; return sn(n-1)*n; } 为什么只有五十分!!!为什么用int代替long long只有50分 #include<iostream> using namespace std; int main() { int i,j,n; int a=1,sum=0; cin>>n; for(i=1;i<=n;i++){ for(j=1;j<=i;j++){ a=a*j; } sum=sum+a; a=1; } cout<<sum<<endl; return 0; }