原题链接:[编程入门]阶乘求和
解题思路:
注意事项:
数据类型要对应
参考代码:
#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 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
//找出规定位数的有效进制的数的个数 #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)