原题链接:[编程入门]阶乘求和
解题思路: 首先我们先了解整型家族(字符、短整型、整型、长整型)的变量的最小范围


1.因为这是阶乘求和,一般的int 类型可能就不够,因此我们利用long long int 类型(不用unsigned long 因为当n为20时,Sn =2561327494111820313)
了,unsigned long的范围不够。
2.求Sn的和,我·用的是两个for循环嵌套
for (int i = 1; i <= n; i++)
	{
		j = 1;   //要在外面for循环执行完一次就初始化一次,要不就带入了内层for循环的值
		for(int m = 0; m < i; m++)  
			j *= (m + 1);    //求出第n个数的n的阶乘
		Sn = Sn + j;  //依次加上阶乘数
	}还可以把我这两个for嵌套变为一个
//借鉴 渴望学到知识的菜鸟 这位博主用的代码
for (int i = 1; i <= n; i++)
    {
        t *= i;
        sum += t;
    }注意事项:  可能很多人多把变量的类型设为int类型导致错误,这里是long long int类型比较合适
参考代码:
#include <stdio.h>
int main(void)
{
	int n;
	long long Sn = 0, j;
	
	scanf("%d", &n); 
	
	for (int i = 1; i <= n; i++)
	{
		j = 1;
		for(int m = 0; m < i; m++)
			j *= (m + 1);
		Sn = Sn + j;
	}
	printf("%lld", Sn); //long long的格式指定符为%lld
	return 0;
}0.0分
82 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
#include<iostream> using namespace std; //求Sn = 1!+ 2!+ 3!+ 4!+ 5!+ … + n!之值,其中n是一个数字(n不超过20)。 int main() { int n = 1; cin >> n; int Sn = 0; for (int j = 1; j <= n; j++) { int prod = 1; for (int i = 1; i <=j; i++) { prod *= i; } Sn += prod; } cout << Sn << endl; }求大佬,我的代码哪里错了,为什么只有50分@灵笼 #include<iostream> using namespace std; //求Sn = 1!+ 2!+ 3!+ 4!+ 5!+ … + n!之值,其中n是一个数字(n不超过20)。 int main() { int n = 1; cin >> n; int Sn = 0; for (int j = 1; j <= n; j++) { int prod = 1; for (int i = 1; i <=j; i++) { prod *= i; } Sn += prod; } cout << Sn << endl; }求大佬,我的哪里错了,结果运行是对的,但是是50分#define _CRT_SECURE_NO_WARNINGS #include <stdio.h> int main() { int a; void j(int x); scanf("%d",&a); if (a >= 0 || a <= 20) j(a); return 0; } void j(int x) { double c = 0; for (int i = 1; i <= x; i++) { double b = 1; for (int k = 1; k <= i; k++) { b *= k; } c += b; } printf("%.0lf", c); } 求大佬解惑,这个为什么错了,明明输出的答案都是对的啊?为什么我的代码不对呢题目不是限制n小于20吗为什么要用很大的范围 #include<stdio.h> int main() { int n,sum,i,k; sum=0; scanf("%d",&n); k=1; while(n>0) { i=n; while(i>0) { k=k*i; i--; } sum=sum+k; k=1; n--; } printf("%d",sum); return 0; }