寻光


私信TA

用户名:RITD

访问量:28148

签 名:

追寻最优解

等  级
排  名 424
经  验 4963
参赛次数 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 人评分

  评论区

麻烦大佬们帮我看看
int fun(int n)
{
    long long a=1 ;
    for (int i = 1; i <= n; i++)
        a = a* i;
    return a;
}

int main()
{
    int n;
    long long sn = 0;
    scanf("%d", &n);
    for (int m = 1; m <= n; m++)
        sn += fun(m);
    printf("%lld", sn);
    return 0;
}
2022-11-02 22:37:49
请大佬们帮我看看为什么只对了一半
#include <stdio.h>
int main ()
{
	
	int j=1; 
	int answer=1;
	int N=0;
	int x=1;
	int Sn=0;
	scanf("%d",&N);
	for(x=1;x<=N;x++){
		do{
			answer*=j;
			j++;
		} while(j<=x);
		Sn+=answer;
		
	
	}
	printf("%d",Sn);
	return 0;
	 

}
2022-09-21 21:45:04
大佬们帮忙看看为啥就对了一半
#include<stdio.h>
int fac(int n){
	if(n == 1) return 1;
	return n*fac(n-1); 
}
int sum(int n){
    long long sum = 0;
	for(int i=1;i<=n;++i){
		sum = sum+fac(i);
	}
	return sum;
}
int main(){
	int n;
	scanf("%d",&n);
	printf("%lld\n",sum(n));
	return 0;
}
2022-07-23 21:25:49
哪位大佬可以帮忙看看这个程序哪里错了,为什么提交后显示是错误的??

#include<stdio.h>

//定义阶乘函数计算n! 
	int jiecheng(int x)
	{
	int i=1,J=1;
	while(i<=x)
	{
		J=1*i*J;
		i++;
	}
     return J;
    }


int main()
{
	int n;
	long long int A,Sn;
	Sn=0;
	scanf("%d",&n);
	if(n<=20)
	{
	for(int i=1;i<=n;i++)
	{
		A=jiecheng(i);
		Sn=Sn+A;
	}
	printf("%lld",Sn);	
	}
	
}
2022-06-25 22:18:43
感谢大佬,提交了四五次没有成功,原来是int字符有限,要用longlong
#include<stdio.h>

int main()
{
    int n, i;
	long long an, Sn;
    scanf("%d", &n);
    for(i = 1, an = 1, Sn = 0; i <= n; i++){
    	an = an * i;
    	Sn = Sn + an;
    	//printf("temporal Sn is %d, temporal an is %d\n", Sn, an);
	}
	printf("%lld", Sn);
	return 0;
}
2022-06-22 22:39:27
#include <stdio.h>

long CalData(int num);

int main(void)
{
    int num = 0;
    scanf("%d",&num);
    long sum = 0;
    for(int i= 1;i <= num;i++)
    {
        sum += CalData(i);
    }
    printf("%ld\n" ,sum);
}

long CalData(int num)
{
    if(num == 0)
    {
        return 1;
    }
    else
    {
        return num * CalData(num - 1);
    }
}
2022-05-23 22:18:42