
C语言:输入精度e 和实数x,用下列公式求cos x 的近似值,精确到最后一项的绝对值小于e。
【问题描述】输入精度e和实数x,用下列公式求cosx的近似值,精确到最后一项的绝对值小于e。要求定义和调用函数funcos(e,x)求余弦函数的近似值...
【问题描述】
输入精度e 和实数x,用下列公式求cos x 的近似值,精确到最后一项的绝对值小于e。要求定义和调用函数funcos(e,x)求余弦函数的近似值。
【输入形式】
输入两个浮点数:精度e和实数x
【输入输出样例1】(下划线部分表示输入)
e: 0.001
x: 1
cos(x)=0.540
【样例说明】
输入提示符后要加一个空格。例如“e: ”,其中“:”后要加一个且只能一个空格。
输出语句的“=”两边无空格
计算结果保留3位小数
英文字母区分大小写。必须严格按样例输入输出。
帮忙改错:
#include<stdio.h>
#include<math.h>
double funcos(double x,double e);
int main(void)
{
double n,x,e;
printf("e:");
scanf("%lf",&e);
printf("x:");
scanf("%lf",&x);
n=funcos(x,e);
printf("cos(x)=%.3f",n);
return 0;
}
double funcos(double x,double e){
int i,k,result=0,fact=1,flag=1;
double sum;
for(i=0;;i+=2){
if(i==0)
fact=1;
else
for(k=1;k<=i;k++){
fact=fact*k;}
sum=flag*pow(x,i)/fact;
if(fabs(sum)<e)
break;
result=result+sum;
flag=-flag;
}
return result;
} 展开
输入精度e 和实数x,用下列公式求cos x 的近似值,精确到最后一项的绝对值小于e。要求定义和调用函数funcos(e,x)求余弦函数的近似值。
【输入形式】
输入两个浮点数:精度e和实数x
【输入输出样例1】(下划线部分表示输入)
e: 0.001
x: 1
cos(x)=0.540
【样例说明】
输入提示符后要加一个空格。例如“e: ”,其中“:”后要加一个且只能一个空格。
输出语句的“=”两边无空格
计算结果保留3位小数
英文字母区分大小写。必须严格按样例输入输出。
帮忙改错:
#include<stdio.h>
#include<math.h>
double funcos(double x,double e);
int main(void)
{
double n,x,e;
printf("e:");
scanf("%lf",&e);
printf("x:");
scanf("%lf",&x);
n=funcos(x,e);
printf("cos(x)=%.3f",n);
return 0;
}
double funcos(double x,double e){
int i,k,result=0,fact=1,flag=1;
double sum;
for(i=0;;i+=2){
if(i==0)
fact=1;
else
for(k=1;k<=i;k++){
fact=fact*k;}
sum=flag*pow(x,i)/fact;
if(fabs(sum)<e)
break;
result=result+sum;
flag=-flag;
}
return result;
} 展开
1个回答
展开全部
#include<stdio.h>
#include<math.h>
double funcos(double x,double e);
int main(void)
{
double n,x,e;
scanf("e: %lf%*c",&e);
scanf("x: %lf%*c",&x);
n=funcos(x,e);
printf("cos(x)=%.3lf",n);
return 0;
}
double funcos(double x,double e){
int i,k,flag=1;
double sum,result=0,fact=1;
for(i=0;;i+=2){
sum=x ;
fact=1;
for(k=1;k<=i;k++)
{
sum *=x ;
fact=fact*k;
}
sum/=fact;
result=result+flag*sum;
if(sum<e)
break;
flag=-flag;
}
return result;
}
#include<math.h>
double funcos(double x,double e);
int main(void)
{
double n,x,e;
scanf("e: %lf%*c",&e);
scanf("x: %lf%*c",&x);
n=funcos(x,e);
printf("cos(x)=%.3lf",n);
return 0;
}
double funcos(double x,double e){
int i,k,flag=1;
double sum,result=0,fact=1;
for(i=0;;i+=2){
sum=x ;
fact=1;
for(k=1;k<=i;k++)
{
sum *=x ;
fact=fact*k;
}
sum/=fact;
result=result+flag*sum;
if(sum<e)
break;
flag=-flag;
}
return result;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询