概述
本题要求实现一个函数,计算下列简单交错幂级数的部分和:
函数接口定义:
double fn( double x, int n );
其中题目保证传入的n是正整数,并且输入输出都在双精度范围内。函数fn应返回上述级数的部分和。建议尝试用递归实现。
裁判测试程序样例:
#include <stdio.h>
double fn( double x, int n );
int main()
{
double x;
int n;
scanf("%lf %d", &x, &n);
printf("%.2fn", fn(x,n));
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
0.5 12
输出样例:
0.33
思路:
对于交错幂级数而言:
当n=3时,f(x,3)=x-x(x-x*x)=x-x2+x3;
当n=4时,f(x,4)=x-x(x-x(x-x*x)=x-x2+x3-x4;
当n=5时,f(x,5)=x-x(x-x(x-x(x-x*x)=x-x2+x3-x4+x5;
…
可以发现,这样展开交错幂级数能让我们更好的理解如何用递归思想求部分和,很显然,递归出口是n=1时的x,而递归调用式是x-x*f(x,n-1)。
代码实现
double fn( double x, int n ){
if(n==1)
return x;
else
return x-x*(fn(x,n-1));
}
这样子写简单得八达鸟!
最后
以上就是谨慎大炮为你收集整理的PTA-C语言 习题10-4 递归求简单交错幂级数的部分和 (15分)的全部内容,希望文章能够帮你解决PTA-C语言 习题10-4 递归求简单交错幂级数的部分和 (15分)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复