原题链接:[编程入门]阶乘求和
解题思路:
利用双层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 <stdio.h> unsigned long long f(int n) { if(n==1) return 1; else return n*f(n-1); } int main() { int i,n; unsigned long long Sn=0; scanf("%d",&n); for(i=0;i<n;i++) { Sn+=f(i+1); } printf("%llu",Sn); return 0; }#include<iostream> using namespace std; int main() { int n,long long Sn=0,i,long long sn=1; cin >> n; while(n--) { for (i = n; i>0 ; i--) { sn = sn * i; } Sn = Sn + sn; sn = 1; } cout << Sn << endl; return 0; } 为什么这样不行呢#include<iostream> using namespace std; int main() { int n; cin >> n; long long sum=0,index=1;//128,425,485,935,180,313 128,425,485,935,180,313 for(int i=1;i<=n;i++){ index*=i; sum+=index; } cout << sum; return 0; } 我试了1~19全部数据,全部正确,为啥提交就WA???#include<stdio.h> #include "stdafx.h" int main() { int s,n,i,a; scanf("%d",&n); if(n>1&&n<20) { s=1; a=1; for(i=1;i<n;i++) { a=a*(i+1); s=s+a; } } if(n==1) s=1; printf("%d\n",s); return 0; } 为什么有错误呢#include<iostream> using namespace std; int main() { int fac(int n); int n; int i; long long Sn=0; cin>>n; for(i=1;i<=n;i++) { Sn=Sn+fac(i); } cout<<Sn; return 0; } int fac(int n) { if(n==1) { return 1; } else return n*fac(n-1); } 谁知道哪里错了?