LYF39 发表于 2021-12-22 14:31:44

关于float和double用法的问题

#include<stdio.h>
int main()

{
        char A;
        int B;
        double C;
        double D;
        double E;
        printf("请输入您的姓名:");
        scanf("%s",A);
        printf("请输入您的身高(cm):");
        scanf("%d",&B);
        printf("请输入您的体重(kg):");
        scanf("%f",&C);
        printf("=========正在为您转换============\n");
        D=B/2.54;
        E=C*2.2;
        printf("%s的身高是%.2f(in),体重是%.2lf(lb)。\n",A,D,E);
        return 0;
}

这里如果C和E使用float是可以对体重进行计算的,但是如果使用double就不可以,然后我查找了之前的求助帖发现很多人说是因为double的输出是%lf,然后我改了之后还是错误,并且我D数据是用的double,最后的输出写的也是%f,但是结果是对的

还有一个问题是下面的编程中我最终输出的结果小数被约掉了,如果我把int换成float或者double就是对的,但是我在想我的B是用的double 理论上来说我计算的B是小数应该是显示出来的啊

#include<stdio.h>
#include<math.h>
int main()
{
        int A;
        double B;
        printf("请输入华氏度:");
        scanf("%d",&A);
        B=(A-32)*5/9;
        printf("转换为摄氏度是:%.2lf",B);
        return 0;
}



刚刚发错版块了,再发一遍

傻眼貓咪 发表于 2021-12-22 14:50:54

报错跟你输出类型没有关系,请注意你的输入
#include<stdio.h>
int main()

{
      char A;
      int B;
      double C;
      double D;
      double E;
      printf("请输入您的姓名:");
      scanf("%s",A);
      printf("请输入您的身高(cm):");
      scanf("%d",&B);
      printf("请输入您的体重(kg):");
      scanf("%lf",&C); // 必须和声明类型一样 double %lf
      printf("=========正在为您转换============\n");
      D=B/2.54;
      E=C*2.2;
      printf("%s的身高是%.2f(in),体重是%.2lf(lb)。\n",A,D,E);
      return 0;
}

LYF39 发表于 2021-12-22 14:55:08

傻眼貓咪 发表于 2021-12-22 14:50
报错跟你输出类型没有关系,请注意你的输入
#include
int main()


感谢{:5_109:}确实是
页: [1]
查看完整版本: 关于float和double用法的问题