(采用两种方法)美国的体积测量系统,计量单位转换(C语言)
在美国的体积测量系统中,1品脱等于2杯,1杯等于8盎司,1盎司等于2大汤勺,1大汤勺等于3茶勺。编写一个程序,提示用户输入杯数,并以品脱、盎司、汤勺、茶勺为单位显示等价容量。思考对于该程序,为何使用浮点类型比整数类型更合适?
编程分析如下:
此问题的主要目的是将用户输入的杯数转换为其他的计量单位。
那为什么使用浮点型而不用整型呐?
主要在于1品脱等于2杯,在其转换过程中会产生半脱品的情况,会带有小数,计算过程中会被计算机舍去,会导致结果不准确。
下面我会采用浮点型和整形分别讲解:(浮点型最合适)
方法一
浮点型程序如下:
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int main() {
float cup;//定义浮点型杯cup
printf("请输入杯数:");
scanf("%f", &cup);//读取用户输入的杯数
printf("%.1f杯是%.1f品脱\n", cup, cup / 2);//1品脱等于2杯
printf("%.1f杯是%.1f盎司\n", cup, cup * 8);//1杯等于8盎司
printf("%.1f杯是%.1f大汤勺\n", cup, cup * 8 * 2);//1盎司等于2大汤勺
printf("%.1f杯是%.1f茶勺\n", cup, cup * 8 * 2 * 3);//1大汤勺等于3茶勺
return 0;
}
输出结果如下:
(取杯数为20)
(取杯数为15)
整型程序如下:
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int main() {
int cup;//定义浮点型杯cup
printf("请输入杯数:");
scanf("%d", &cup);//读取用户输入的杯数
printf("%.d杯是%.d品脱\n", cup, cup / 2);//1品脱等于2杯
printf("%.d杯是%.d盎司\n", cup, cup * 8);//1杯等于8盎司
printf("%.d杯是%.d大汤勺\n", cup, cup * 8 * 2);//1盎司等于2大汤勺
printf("%.d杯是%.d茶勺\n", cup, cup * 8 * 2 * 3);//1大汤勺等于3茶勺
return 0;
}
(取杯数为15)
方法二
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#define pin_cup 2//定义符号常量
#define ang_cup 8
#define tang_cup 2
#define cha_cup 3
int main() {
float pint, cup, ounce, spoon, tea;//定义浮点型
printf("请输入杯数:");
scanf("%f", &cup); //读取用户输入的杯数
pint = cup / pin_cup; //1品脱等于2杯
ounce = cup * ang_cup; //1杯等于8盎司
spoon = ounce * tang_cup; //1盎司等于2大汤勺
tea = spoon * cha_cup; //1大汤勺等于3茶勺
printf("%.1f杯是%.1f品脱\n", cup, pint);
printf("%.1f杯是%.1f盎司\n", cup, ounce);
printf("%.1f杯是%.1f大汤勺\n", cup, spoon);
printf("%.1f杯是%.1f茶勺\n", cup, tea);
return 0;
}
输出结果如下:
由上面程序知:使用整型时小数点后面的数会被舍去,导致计算结果不准确。所以说浮点型比整型更合适。
ikunxx1: 我想问一下,到两百的要加什么东西才能让130-140全标识出来呢
炑瞳: 如果体重相等怎么办
心想事橙的梨子: #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> int main() { float C,F;//定义浮点型变量C,F表示华氏温度,摄氏温度 printf("请输入一个华氏温度:\n"); scanf("%f", &F);//读取用户输入 C = (F - 32) / 1.8; printf("华氏温度%.2f的摄氏温度是:%.2f\n",F,C); return 0; }
sczyh1: count不多余吗
2302_79191240: 第二个我怎么使用不对?