C语言——求cos(x)的近似值

2023-12-13 17:50:15

归纳编程学习的感悟,
记录奋斗路上的点滴,
希望能帮到一样刻苦的你!
如有不足欢迎指正!
共同学习交流!
🌎欢迎各位→点赞 👍+ 收藏? + 留言?📝
没有存储汗水,就无法支取成长!

一起加油!

这我们利用泰勒公式求cos(x)的近似值。

什么是泰勒公式?????????? ? ? ?

????????泰勒公式,是一个用函数在某点的信息描述其附近取值的公式。如果函数满足一定的条件,泰勒公式可以用函数在某一点的各阶导数值做系数构建一个多项式来近似表达这个函数。

泰勒公式得名于英国数学家布鲁克·泰勒,他在1712年的一封信里首次叙述了这个公式。泰勒公式是为了研究复杂函数性质时经常使用的近似方法之一,也是函数微分学的一项重要应用内容。

代码实现:?

#include<stdio.h>
#define Pi 3.1415926

double my_cos(double x);//cos函数声明 
double my_pow(double x, int i);//求x的n次方 
double factorial(int i);//阶乘函数声明 

int main(){
	double x;
	printf("请输入x的值:"); 
	scanf("%lf",&x); 
	printf("原式=%.2f\n",my_cos(x));//调用cos函数 
	return 0;
}

double my_cos(double x)//cos函数定义 
{
	while(x>2*Pi) x-=2*Pi;//控制区间在0到2Pi 
	while(x<0) x+=2*Pi;
	//利用cos(x)的泰勒展示求cos(x)的近似值
	double index,result=0;
	int i=0;
	do{
		index=my_pow(x,i)/factorial(i);
		result += my_pow(-1,i/2) * index;
		i += 2;
	} while(index>1e-6);
	return result;
}

double my_pow(double x, int i)
{
	//利用递归函数实现pow函数 
	if(i==0) return 1;
	if(i>0) return x*my_pow(x, i-1);
	if(i<0) return 1/x*my_pow(x, i+1);
}

double factorial(int i){
	//利用的递归函数求阶乘 
	if(i==0) return 1;
	else return i*factorial(i-1);
}

文章来源:https://blog.csdn.net/2301_80585598/article/details/134903038
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。