当我输入0.50或其他可以被除以的浮点数时,0.25我不会得到任何错误,但是当我输入0.10或无法被我编写0.25的elseif语句除以的浮点数时,不会发生。谁能告诉我为什么?
#include <cs50.h>
#include <stdio.h>
#include <math.h>
int main(void) {
float change;
do {
change = get_float("Change owed: ");
} while (change < 0.009);
int count = 0;
int div = 0;
while (change > 0.00) {
if ((change / 0.25) >= 1.00) {
div = round(change / 0.25);
count += div;
change = change - (div *0.25);
} else
if ((change / 0.10) >= 1.00) {
div = round(change / 0.10);
count += div;
change = change - (div * 0.10);
} else
if ((change / 0.05) >= 1.00) {
div = round(change / 0.05);
count += div;
change = change - (div * 0.05);
} else {
div = round(change / 0.01);
count += div;
change = change - (div * 0.01);
}
}
printf("%i\n", count);
}
Run Code Online (Sandbox Code Playgroud)
浮点数C的内部表示几乎始终是IEEE 754二进制表示中指定的二进制格式,而不是十进制形式。结果,一些数字用简单的十进制表示法表示,例如0.1未在a float或什至在double变量中准确表示。将此变量乘以10并不一定能1精确得出值,而是一个非常接近的浮点数,与不同1。比较浮点数时应格外小心,要考虑到舍入方法的传播会产生小的差异。特别是,您应避免使用float或double对于精确到美分的货币值:使用一个整数,该美分的大小足以处理所计算的数字。常规的32位int数字不足以美分表示的2,000万美元以上的数字。
这是使用long int至少32位大小的修改版本:
#include <cs50.h>
#include <stdio.h>
#include <math.h>
int main(void) {
float change = get_float("Change owed: ");
long int cents = round(change * 100); // get an exact number of cents.
long int count = cents / 25; // number of quarters
cents %= 25;
count += cents / 10; // number of dimes
cents %= 10;
count += cents / 5; // number of nickels
cents %= 5;
count += cents; // number of pennies
printf("%ld coins\n", count);
return 0;
}
Run Code Online (Sandbox Code Playgroud)