解题思路:递归写一个阶乘函数,然后自定义一个幂函数,最后主函数调用即可。注意double数据类型如何一直保持double的问题!!!不要与整型数据进行乘除计算即可,如果遇到了记得转换一下。
注意事项:①阶乘函数,注意n==1的情况;②幂函数,注意x==1的情况;③double类型输入时是%lf类型,float和double类型输出时均为%f。
参考代码:
#include <stdio.h>
double fact(double n) {//阶乘函数,注意n==1的情况
if (n == 1)return 1;
return n * fact(n - 1);
}
double mypow(double x, double n) {//幂函数,注意x==1的情况
double e = 1.0;
if (x == 1) { return x; }
for (int i = 0; i < n; ++i) {
e = e * x;
}
return e;
}
int main() {
double x;
int n;
scanf("%lf%d", &x, &n);//double类型输入时时lf类型,float和double类型输出时均为%f
double sum = 0.0;
for (int i = 1; i <= n; ++i) {
sum = sum + mypow(-1, i - 1) * mypow(x, i) / fact(i);
}
printf("%.4f", sum);
return 0;
}
0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复