panmmmy 发表于 2021-10-17 01:20:48

c语言求助, S1E8:字符和字符串 | 课后习题求职

#include <stdio.h>

int main()
{
      char name;//256 是什么
      float height, weight;//为什么不能用 unsigned char

      printf("请输入您的姓名:");
      scanf("%s", name);

      printf("请输入您的身高(cm):");
      scanf("%f", &height);

      printf("请输入您的体重(kg):");
      scanf("%f", &weight);

      printf("========== 正在为您转换 ==========\n");

      height = height / 2.54;
      weight = weight / 0.453;

      printf("%s的身高是%.2f(in),体重是%.2f(lb)。\n", name, height, weight);

      return 0;
}


提问:
1.char name; //括号内256是什么意思,为什么不可以省略256,写为char name[]

2.float height, weight; //为什么不能和课上一样使用 unsigned char?

3.double/float 如何选择,为什么计算整数值的时候也能选择double?

期待能够得到解答,感谢

大马强 发表于 2021-10-17 08:43:51

1、c语言规定声明数组的时候就要定义它的大小,所以256是他的大小即存放256个字符,也可以这样char a[] ="abcd"
2、第二个问题和实际运用有关,你体重一般都用浮点数表示,那你想用unsigned char来替代不是狗抓耗子多管闲事吗
3、double的精度会高于float,建议使用double,但是两者的scanf的格式化参数是不一样的,一个是%lf,一个是%f,

傻眼貓咪 发表于 2021-10-17 09:05:06

本帖最后由 傻眼貓咪 于 2021-10-17 09:06 编辑

ASCII + EASCII 刚好 256 个字符
float 是浮点数,unsigned char 是无符字符。体重和身高用浮点数比较适合吧(c 语言数据类型很多,什么时候该用什么是自己决定的,体重身高用浮点,数量用整数,名字用字符串,这些都是日常逻辑啊)
如 2楼大佬说的,double 精度比 float 高,比如:#include <stdio.h>

int main()
{
    // 这里用 float
    float a, b;
    a = 7.0;
    b = 720000*(1-a/10);
    printf("%f", b);
   
    printf("\n");
   
    // 这里用 double
    double x, y;
    x = 7.0;
    y = 720000*(1-x/10);
    printf("%f", y);
   
    return 0;
}216000.015625
216000.000000你会发现用同样算法,明显 double 比 float 精度更高
页: [1]
查看完整版本: c语言求助, S1E8:字符和字符串 | 课后习题求职