#include <stdio.h>
#include <math.h>
double funcos( double e, double x );
int main()
{
double e, x;
scanf("%lf %lf", &e, &x);
printf("cos(%.2f) = %.6f\n", x, funcos(e, x));
return 0;
}
/*
你的代码将被嵌在这里
*/
double funcos( double e, double x )
{
int i,j;
double pwr;
int factorial = 1;
double cos = 0;
double last_cos = 0;
for (i=0;;i+=2)
{
printf("ok");
factorial = 1;
for (j=1;j<i;++j)
{
factorial*=j;
}
pwr = pow(x,i);
last_cos = pwr/factorial;
if((last_cos>0 && last_cos<e) || (last_cos<0 && -last_cos<e))
cos += last_cos;
else
break;
}
return cos;
}
![img](https://img-mid.csdnimg.cn/release/static/image/mid/ask/986268673836142.jpg "#left")
```**这道题这样写哪里不对,结果总是0,求原因**********
![](https://profile-avatar.csdnimg.cn/default.jpg!4)
PTA 6-2 疑难杂症求解
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- bekote 2021-12-02 09:47关注
double funcos( double e, double x ) { int i,j; double pwr; int factorial = 1; double cos = 0; double last_cos = 0; for (i=0;;i+=2) { factorial = 1; //阶乘到i for (j=1;j<=i;++j) { factorial*=j; } pwr = pow(x,i); last_cos = pwr/factorial; cos += last_cos; //最后一项小于e就停止计算 if((last_cos>0 && last_cos<e) || (last_cos<0 && -last_cos<e)) break; } return cos; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用
- ¥100 vc++混合CEF采用CLR方式编译报错
- ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
- ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
- ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
- ¥50 如何openEuler 22.03上安装配置drbd
- ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
- ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
- ¥15 Windows11, backspace, enter, space键失灵