m0_63508730 2021-12-02 00:44 采纳率: 100%
浏览 24
已结题

PTA 6-2 疑难杂症求解


#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,求原因**********
  • 写回答

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;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 12月17日
  • 已采纳回答 12月9日
  • 创建了问题 12月2日

悬赏问题

  • ¥30 informer时间序列预测
  • ¥20 SSR引物多态性分析
  • ¥15 大漠插件在Win11易语言注册调用和免注册灵异事件,VS上注册调用完全没问题
  • ¥15 Addressable缓存机制做热更新的问题
  • ¥15 微信开发者工具vant组件
  • ¥15 iPhone iCloud云盘资料删除,MAC丢失50多G桌面资料
  • ¥20 希望各位学长可以给我答疑
  • ¥20 Linux实现: 客户端(cli01)通过TCP(或UDP)连接到聊天服务器(serv)进行聊天。
  • ¥15 (标签-matlab|关键词-m3)
  • ¥20 自制cifar10数据集,生成的batch缺少key:b