首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >带浮点的C语言中的现金除法错误

带浮点的C语言中的现金除法错误
EN

Stack Overflow用户
提问于 2019-05-14 20:17:04
回答 3查看 209关注 0票数 1

我目前正在研究cs50的“现金”问题:估计需要支付一些零钱的硬币数量。

例如:0.41美元=1个25美分,1个10美分,1个5美分,1便士。

然而,当估计所需的硬币数量时,我最终得到的是便士,我认为这是由于我的错误,因为它似乎总是偏离一到两个硬币(便士)。

我已经包含了多个printf语句来尝试跟踪我可以做的事情,但是我似乎不明白为什么这个部门不能工作。

#include <cs50.h>
#include <stdio.h>

int main(void)
{
    // change
    float change = get_float("how much change is owed?: ");
    int coins = 0;

    //reprompt
    while (change < 0)
    {
        change = get_float("how much change is owed?: ");
    }

    //quarter
    float quarter = 0.25;
    float quarters = change / quarter;
    quarters = (int) quarters;
    change = change - (quarters * quarter);

    printf("%f quarters\n", quarters);

    //dimes
    float dime = 0.10;
    float dimes = change / dime;
    dimes = (int) dimes;
    change = change - (dimes * dime);

    printf("%f dimes\n", dimes);

    //nickels
    float nickel = 0.05;
    float nickels = change / nickel;
    nickels = (int) nickels;
    change = change - (nickels * nickel);

    printf("%f nickels\n", nickels);
    printf("%f in change left change\n", change);

    //pennies
    float penny = 0.010000;
    float pennies = change / penny;
    pennies = (int) pennies;
    change = change - (pennies * penny);

    printf("%f pennies\n", pennies);

    //coins
    coins = quarters + dimes + nickels + pennies;
    printf("%i\n", coins);

    //printf("%f\n", change);
}
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2019-05-14 20:43:45

在你的C实现中,这些代码行:

float dime = 0.10;
float nickel = 0.05;
float penny = 0.010000;

dime设置为0.100000001490116119384765625,将nickel设置为0.0500000007450580596923828125,将penny设置为0.00999999977648258209228515625。这会导致每枚硬币的计算略有偏差。此外,在处理每个硬币之后的change的计算具有舍入误差。

要解决此问题,在使用get_float获取change后,使用以下命令将其转换为几美分:

int cents = roundf(change * 100);

然后使用整数运算执行所有计算。(包含<math.h>以获取roundf的声明。)

票数 4
EN

Stack Overflow用户

发布于 2019-05-14 20:42:05

从下面这行开始:

#include <math.h>


#define PENNIES_IN_GBP (100)


int main(void)
{
        int change_pn = roundf(PENNIES_IN_GBP * get_float("how much change is owed?: "));

        /* ... */

        return 0;
}

其余的应该很容易;)

票数 1
EN

Stack Overflow用户

发布于 2019-05-14 21:01:02

这只是一个建议,为什么不用整数算术来执行所有的计算呢?将浮点数"change“转换为整数”美分“

(int) cents = roundf(100.0 * change); // see comments below answer

然后将所有内容保留为整数,例如

//quarter
const int quarter = 25;
int quarter_count = cents / quarter;
cents = cents % quarter; // use modulus operator

我还可以建议,使用非常相似的变量名称,例如quarter和quarters,可能会导致错误。

因为您永远不会想要更改一个季度中的美分数(特别是意外地),所以您可以将其声明为const int。

您可能还想检查用户是否输入了他们认为是美元的小数(浮点数),而不是整数美分。但这超出了这个问题的范围。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56130276

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档