解题思路:


利用双层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 ;
}


点赞(10)
 

0.0分

50 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 47 条评论

Cauchy 4年前 回复TA
@Cauchy 递归:f(n)=n*f(n-1)
Cauchy 4年前 回复TA
#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;
}
象帝之先 4年前 回复TA
@你好 不同类型定义变量要分开定义用;隔开    while循环的限制条件有问题,判断时的n和循环内的n不一样大,建议不要用while
你好 4年前 回复TA
#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;
}
为什么这样不行呢
冲进前五百冲鸭 4年前 回复TA
@菜鸟阿壹 如果n等于1 是不是s和a就属于未定义呢
冲进前五百冲鸭 4年前 回复TA
@eason ????你这个....是一个数的阶乘啊,不是阶乘求和吧!
eason 4年前 回复TA
#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???
菜鸟阿壹 4年前 回复TA
#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;
} 为什么有错误呢
加油吧 4年前 回复TA
@正在路上ing 这样是错的
你的全世界 4年前 回复TA
#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);
}
谁知道哪里错了?