这是一个简单的问题,在给定N值的情况下计算给出变化所需的最小硬币数。除法0.04 / 0.01给出3,为什么?
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int MinQtdCoins(float N, float coins[], int qtdCoins)
{
int i, qtdMinCoins = 0;
int numCoins=0;
for(i=0; i<qtdCoins; i++)
{
if(N > coins[i] || fabs(N - coins[i]) < 0.0000000001) // N >= coins[i]
{
numCoins = (int)(N/coins[i]);
printf("Number of Coins: %f divided by %f = %d, ",N,coins[i],numCoins);
qtdMinCoins += numCoins;
N = N - numCoins*coins[i];
printf("remains: %f\n",N);
}
}
return qtdMinCoins;
}
int main()
{
int qtdCoins = 5;
float coins[] = {0.50, 0.25, 0.10, 0.05, 0.01};
float N=9.79;
printf("\n\n%d\n",MinQtdCoins(N, coins, qtdCoins));
return 0;
}
答案 0 :(得分:5)
分度0.04 / 0.01给出3,为什么?
numCoins = (int)(N/coins[i]);
转换为int
只会截断小数部分。因此,如果0.04/0.01 == 3.999..
(由于四舍五入),结果为3
。
答案 1 :(得分:0)
你正在进行浮点除法并将值保持为整数...因为这个值被截断为3