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?
期待能够得到解答,感谢
1、c语言规定声明数组的时候就要定义它的大小,所以256是他的大小即存放256个字符,也可以这样char a[] ="abcd"
2、第二个问题和实际运用有关,你体重一般都用浮点数表示,那你想用unsigned char来替代不是狗抓耗子多管闲事吗
3、double的精度会高于float,建议使用double,但是两者的scanf的格式化参数是不一样的,一个是%lf,一个是%f, 本帖最后由 傻眼貓咪 于 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]