原题链接:[编程入门]阶乘求和
解题思路:
利用双层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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
int factor(int n); int main() { int n,i; int fac=0; printf("please input n:"); scanf("%d",&n); for(i=1;i<=n;i++) fac+=factor(i); printf("1!+..%d!=%d",n,fac); } int factor(int n) { int k,j=1;; for(k=1;k<=n;k++) j*=k; return j; }#include<stdio.h> int main() { long long n,a=1; long long Sn=0; scanf("%lld",&n); for(int i=1;i<=n;i++){ a=a*i; Sn=Sn+a; } printf("%lld",Sn); return 0; }#include<stdio.h> int main() { int a; long long n = 0, t = 1; scanf("%d", &a); for ( int i = 1; i < a; i++) { t = t * (i + 1); n += t; } printf("%lld", n + 1); return 0; }