我是靠谱客的博主 谨慎大炮,最近开发中收集的这篇文章主要介绍PTA-C语言 习题10-4 递归求简单交错幂级数的部分和 (15分),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

本题要求实现一个函数,计算下列简单交错幂级数的部分和:

在这里插入图片描述
函数接口定义:

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分)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(57)

评论列表共有 0 条评论

立即
投稿
返回
顶部