大欧666 2022-10-16 16:50 采纳率: 66.7%
浏览 18
已结题

请问这个代码为啥double的x不能用scanf输入定义,但是改成float类型的x却可以呢


//利用泰勒公式求sin(x)的值。
#include<stdio.h>
#include<math.h>
#define esp 1e-5
void main()
{
    int n;
    double x,term,sum=0;
    scanf("%f",&x);
    term=x;
    n=1;
    while(fabs(term)>esp)
    {
        sum+=term;
        n+=2;
        term=term*(-1*x*x)/n/(n-1);
    }
    printf("sin(x)=%.20f",sum);
}

  • 写回答

1条回答 默认 最新

  • 快乐鹦鹉 2022-10-16 17:18
    关注

    double用%lf输入

    scanf("%lf",&x);

    float类型用%f输入

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月24日
  • 已采纳回答 10月16日
  • 创建了问题 10月16日

悬赏问题

  • ¥15 如何绘制动力学系统的相图
  • ¥15 对接wps接口实现获取元数据
  • ¥20 给自己本科IT专业毕业的妹m找个实习工作
  • ¥15 用友U8:向一个无法连接的网络尝试了一个套接字操作,如何解决?
  • ¥30 我的代码按理说完成了模型的搭建、训练、验证测试等工作(标签-网络|关键词-变化检测)
  • ¥50 mac mini外接显示器 画质字体模糊
  • ¥15 TLS1.2协议通信解密
  • ¥40 图书信息管理系统程序编写
  • ¥20 Qcustomplot缩小曲线形状问题
  • ¥15 企业资源规划ERP沙盘模拟