我不知道为什么if语句不发生

1 c cs50

当我输入0.50或其他可以被除以的浮点数时,0.25我不会得到任何错误,但是当我输入0.10或无法被我编写0.25elseif语句除以的浮点数时,不会发生。谁能告诉我为什么?

#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)

chq*_*lie 6

浮点数C的内部表示几乎始终是IEEE 754二进制表示中指定的二进制格式,而不是十进制形式。结果,一些数字用简单的十进制表示法表示,例如0.1未在a float或什至在double变量中准确表示。将此变量乘以10并不一定能1精确得出值,而是一个非常接近的浮点数,与不同1。比较浮点数时应格外小心,要考虑到舍入方法的传播会产生小的差异。特别是,您应避免使用floatdouble对于精确到美分的货币值:使用一个整数,该美分的大小足以处理所计算的数字。常规的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)