用c语言编写cosx函数

用余弦函数(cosx)的幂级数展开式编写程序:(1)要求从控制台输入x的值,依据上述cosx的幂级数展开式,输出cosx的近似值;(2)要求计算结果精确到小数点后8位。(... 用余弦函数(cosx)的幂级数展开式编写程序:
(1) 要求从控制台输入x的值,依据上述cosx的幂级数展开式,输出cosx的近似值;
(2) 要求计算结果精确到小数点后8位。
(3) 注意:不允许使用C标准函数库(math.h)中的余弦函数。

#include<stdio.h>
#include<math.h>
int main()
{
int n=0;
double x,sum=0;
printf("please enter x:");
scanf("%f",&x);
double cosx(double x,int n);
do
{
sum=sum+cosx(x,n);
n=n+1;
}
while(fabs(cosx(x,n))>1e-8);
printf("%9.8f\n",sum);
return 0;
}
double cosx(double x,int n)
{
double p;
int q;
p=pow(x,2*n);
int fact(int n);
q=fact(2*n);
if(n%2)
return(-p/q);
else
return(p/q);
}
int fact(int n)
{
int ans=1,i;
if(n<=1)
return 1;
for(i=1;i<=n; ++i)
ans*=i;
return ans;
}
输不出结果结果,求帮助!
展开
 我来答
岁月就这么说
推荐于2016-06-04 · 知道合伙人教育行家
岁月就这么说
知道合伙人教育行家
采纳数:9542 获赞数:132499

向TA提问 私信TA
展开全部
  cosx函数
  #include<stdio.h>
  #include<math.h>
  int main()
  {
  int n=0;
  double x,sum=0;
  printf("please enter x:");
  scanf("%lf",&x);//
  double cosx(double x,int n);
  do
  {
  sum=sum+cosx(x,n);
  n=n+1;
  }
  while(fabs(cosx(x,n))>1e-8);
  printf("%9.8f\n",sum);
  return 0;
  }
  double cosx(double x,int n)
  {
  double p,q;//
  p=pow(x,2*n);
  double fact(int n);//
  q=fact(2*n);
  if(n%2)
  return(-p/q);
  else
  return(p/q);
  }
  double fact(int n)//
  {
  double ans=1; int i;
  if(n<=1)
  return 1;
  for(i=1;i<=n; ++i)
  ans*=i;
  return ans;
  }

  cosx函数即反余弦函数

  函数y=cosx(x∈[0,π])的反函数叫做反余弦函数,
  记作y=arccosx(x∈[-1,1]).
百度网友7eff2e0
推荐于2017-12-15 · TA获得超过1043个赞
知道小有建树答主
回答量:787
采纳率:80%
帮助的人:529万
展开全部
错误有两类:
1. scanf("%f",&x);由于x是double型,所以应改成scanf("%lf",&x);
2. fact()和cosx()中用int型来计算n!会很快溢出,应改为double型

改后如下,运行正确。
#include<stdio.h>
#include<math.h>
int main()
{
int n=0;
double x,sum=0;
printf("please enter x:");
scanf("%lf",&x);//
double cosx(double x,int n);
do
{
sum=sum+cosx(x,n);
n=n+1;
}
while(fabs(cosx(x,n))>1e-8);
printf("%9.8f\n",sum);
return 0;
}
double cosx(double x,int n)
{
double p,q;//
p=pow(x,2*n);
double fact(int n);//
q=fact(2*n);
if(n%2)
return(-p/q);
else
return(p/q);
}
double fact(int n)//
{
double ans=1; int i;
if(n<=1)
return 1;
for(i=1;i<=n; ++i)
ans*=i;
return ans;
}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式