5-7 使用函数求余弦函数的近似值

//使用函数求余弦函数的近似值
//算的误差很大? 
//因为循环判断条件中忘加fabs了 

#include<stdio.h>
#include<math.h>

double funcos(double e,double x);
double fact(int n);
int main(int argc,char const *argv[])
{
	double e,x;
	printf("请输入精度e和自变量x:");
	scanf("%lf%lf",&e,&x);
	
	printf("我算的:cos(%.2f)=%.4f\n",x,funcos(e,x));
	
	printf("计算机算的:cos(%.2f)=%.4f\n",x,cos(x));
	
	return 0;
} 

double funcos(double e,double x)
{
	int flag=1,cnt=0;
	double item=1.0;
	double cosine=0;
	
	while(fabs(item)>=e)
	{
		item=flag*pow(x,cnt)/fact(cnt);
		cosine+=item;
		flag=-flag;
		cnt+=2;
	}
	
	return cosine;
}

double fact(int n)
{
	int i;
	double fact=1;
	for(i=1;i<=n;i++)
	{
		fact*=i;
	}
	
	return fact;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值