寻光


私信TA

用户名:RITD

访问量:28148

签 名:

追寻最优解

等  级
排  名 424
经  验 4958
参赛次数 0
文章发表 13
年  龄 20
在职情况 学生
学  校 East Electricity
专  业 计科

  自我简介:

很菜所以很努力

解题思路:   首先我们先了解整型家族(字符、短整型、整型、长整型)的变量的最小范围

屏幕截图 2022-04-02 132919.png

屏幕截图 2022-04-02 133112.png



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分

110 人评分

  评论区

看看吧,对一半
#include<stdio.h>
int c[100]={1};
int factorial(int a)
{
	if(c[a]!=0)return c[a];
	else 
	{
		c[a]=c[a-1]*a;
		return c[a];
	}
}
int main()
{
	int n;
	scanf("%d",&n);
	int sum=0;
	for(int i=1;i<=n;i++)
	{
		int b=factorial(i);
		sum+=b;
	}
	printf("%d",sum);
	
	return 0;
}
2024-11-17 20:56:32
#include <stdio.h>
int jiecheng(int x) 
{
    int i, result = 1;
    for (i = 1; i <= x; i++) 
    {
        result *= i;
    }
    return result;
}

int main() 
{
    int Sn, n;
    scanf("%d", &n); 
    for (; n >= 1; n--) 
    {
        Sn+= jiecheng(n);
    }
    printf("%d ", Sn);
    return 0;
}
这个代码输入5,输出153,但还是不对
2024-11-11 22:02:05
#include <stdio.h>
int main() 
{
	int i,z,n;
	long long s=0,j=1;
	scanf("%d",&n);
	z=n-1;
	for(i=1;i<n+1;i++,z--)
	{
		j=j*(n-z);
		s=s+j;
	}
	printf("%lld",s);
	return 0;
}
2024-08-07 10:23:13
#include<stdio.h>
int fac(int num);
int main()
{
	int n,sn=0;
	scanf("%d",&n);
	for(int i=1;i<=n;i++)
	{
		sn = sn + fac(i);
	}
	printf("%d",sn);
	return 0;
}

int fac(int num)
{
	int product = 1;
	while(num!=0)
	{
		product = product * num;
		num--;
	}
}
有没有大佬帮忙看一下这个为什么错了
2024-08-01 10:44:03
#include<stdio.h>
int main(void)
{
    int n;
    long long int j=1;
    long long int sum=0;
    scanf("%d",&n);
    for(int i=1;i<=n;i++){
    j=j*i;
    sum=sum+j;
	}
	printf("%lld",sum);
	return 0;
}
2024-07-20 18:41:04
#include<stdio.h>
int main(){
	int n;
	int Sn=0;
	scanf("%d",&n);	
	for(int i=1;i<=n;i++)
	{	int an=1;
		for(int j=1;j<=i;j++)
		{
			an=an*j;
		
		}
		Sn=Sn+an;
	}
	printf("%d",Sn);
	return 0;
}


个位大佬谁帮我看看为啥只有50分啊啊啊啊
2024-06-12 16:58:32
#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分
2024-03-21 18:38:21
#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);
}
求大佬解惑,这个为什么错了,明明输出的答案都是对的啊?
2024-03-16 00:00:29