解题思路:





注意事项:

数据类型要对应



参考代码:

#include<stdio.h>

long aa(int n);

int main()

{

    int i,n;

    scanf("%d",&n);

    long Sn=0;

    if(n>=0&&n<=20){

    for(i=1;i<=n;i++)

        Sn+=aa(i);}

    printf("%ld",Sn);

    return 0;

}

long aa(int n)

{

    long i,b=1;

    for(i=1;i<=n;i++)

    {

        b*=i;

    }

    return b;

}


点赞(0)
 

0.0分

0 人评分

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

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

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

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

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

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

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

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

评论列表 共有 1 条评论

深圳孩 4年前 回复TA
//找出规定位数的有效进制的数的个数
#include<stdio.h>
 int getSum(int N,int K); 
int main()
{
	int N,K,sum;
	scanf("%d%d",&N,&K);
	//当只有1位数的时候比较特殊,就只调用一次,且应该返回进制那么多,所以在原本调用的基础上+1,因为有0 
	 if(N==1)
	 {
	 	sum=getSum(N,K)+1;
	  } 
	else
	{
		sum=getSum(N,K)-getSum(N-1,K);
	 } 
	printf("%d",sum);
	return 0;
 } 
 //1位10进制:0-9:10个,最大的数字为9 
 //2为10进制:99-9:90,用2位十进制最大的数字-1为十进制最大的数字 
 //3为10进制:999-99,用3为十进制最大的数字-2位十进制最大的数字 
 int getSum(int N,int K)