为什么我的2022 CS50现金贪婪算法会输出不同数量的硬币,然后手动计算?
我要进行CS50X,而没有编码的事先了解,并将其陷入第二周问题集1。这是一个贪婪的算法问题,其中该程序计算了要偿还更改的硬币数量。该代码通过CS50自动检查,但在自我检查上存在问题。
例子: 如果我在提示中输入5更改,则应该给我2个硬币 - 一个镍和一分钱(5 + 1),但代码代替输出4个硬币。 如果我在提示上输入160更改(与CS50检查工具的用途相同),则应该给我7个硬币 - 六个季度和一个一角钱(6 + 1)。相反,此代码为我提供了9个硬币。
我挠头,因为如果我使用计算器并手动通过循环时进行操作,那么输出应该输出的内容是有意义的,但是显然,程序的工作方式不同。
有什么想法吗?
#include <cs50.h>
#include <stdio.h>
int get_cents(void);
int calculate_quarters(int cents);
int calculate_dimes(int cents);
int calculate_nickels(int cents);
int calculate_pennies(int cents);
int main(void)
{
// Ask how many cents the customer is owed
int cents = get_cents();
// Calculate the number of quarters to give the customer
int quarters = calculate_quarters(cents);
cents = cents - quarters * 25;
// Calculate the number of dimes to give the customer
int dimes = calculate_dimes(cents);
cents = cents - dimes * 10;
// Calculate the number of nickels to give the customer
int nickels = calculate_nickels(cents);
cents = cents - nickels * 5;
// Calculate the number of pennies to give the customer
int pennies = calculate_pennies(cents);
cents = cents - pennies * 1;
// Sum coins
int coins = quarters + dimes + nickels + pennies;
// Print total number of coins to give the customer
printf("%i\n", coins);
}
int get_cents(void)
{
//Ask for how much change is owed
int cents = 0;
do
{
cents = get_int("Change owed: ");
}
while (cents <= 0);
return cents;
}
int calculate_quarters(int cents)
{
//Continue to check for how many quarters fit into input amout of change
int quarters = 0;
do
{
cents = cents - 25;
quarters++;
}
while (cents >= 25);
return quarters;
}
int calculate_dimes(int cents)
{
//Continue to check for how many cents fit into input amout of change after subtracting quarters
int dimes = 0;
do
{
cents = cents - 10;
dimes++;
}
while (cents >= 10);
return dimes;
}
int calculate_nickels(int cents)
{
int nickels = 0;
do
{
cents = cents - 5;
nickels++;
}
while (cents >= 5);
return nickels;
}
int calculate_pennies(int cents)
{
int pennies = 0;
do
{
cents = cents - 1;
pennies++;
}
while (cents >= 1);
return pennies;
}
I'm taking a CS50x without prior knowledge of coding and am kind of stuck on the 2nd Week problem set 1. This is a greedy algorithm problem, in which the program calculates the number of coins to be given to pay back the change. The code passes CS50 automatic check, but it has issues on self-check.
Example:
If I input 5 change on prompt, it is supposed to give me 2 coins - one nickel and one penny (5 + 1), but the code instead outputs 4 coins.
If I input 160 change on prompt (same as cs50 check tool uses), it is supposed to give me 7 coins - six quarters and one dime ( 6 + 1). Instead, this code gives me 9 coins.
I'm scratching my head because if I use the calculator and go manually through the do while loops, it makes sense to output what it is supposed to be output, but, apparently, the program works differently.
Any ideas?
#include <cs50.h>
#include <stdio.h>
int get_cents(void);
int calculate_quarters(int cents);
int calculate_dimes(int cents);
int calculate_nickels(int cents);
int calculate_pennies(int cents);
int main(void)
{
// Ask how many cents the customer is owed
int cents = get_cents();
// Calculate the number of quarters to give the customer
int quarters = calculate_quarters(cents);
cents = cents - quarters * 25;
// Calculate the number of dimes to give the customer
int dimes = calculate_dimes(cents);
cents = cents - dimes * 10;
// Calculate the number of nickels to give the customer
int nickels = calculate_nickels(cents);
cents = cents - nickels * 5;
// Calculate the number of pennies to give the customer
int pennies = calculate_pennies(cents);
cents = cents - pennies * 1;
// Sum coins
int coins = quarters + dimes + nickels + pennies;
// Print total number of coins to give the customer
printf("%i\n", coins);
}
int get_cents(void)
{
//Ask for how much change is owed
int cents = 0;
do
{
cents = get_int("Change owed: ");
}
while (cents <= 0);
return cents;
}
int calculate_quarters(int cents)
{
//Continue to check for how many quarters fit into input amout of change
int quarters = 0;
do
{
cents = cents - 25;
quarters++;
}
while (cents >= 25);
return quarters;
}
int calculate_dimes(int cents)
{
//Continue to check for how many cents fit into input amout of change after subtracting quarters
int dimes = 0;
do
{
cents = cents - 10;
dimes++;
}
while (cents >= 10);
return dimes;
}
int calculate_nickels(int cents)
{
int nickels = 0;
do
{
cents = cents - 5;
nickels++;
}
while (cents >= 5);
return nickels;
}
int calculate_pennies(int cents)
{
int pennies = 0;
do
{
cents = cents - 1;
pennies++;
}
while (cents >= 1);
return pennies;
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
您使用
do
/而
循环来计算每种硬币的数量,因此,您始终至少计算每种硬币的一枚硬币,这是不正确的。例如,如果您有2美分要分发,您将获得1季度,Cents
将成为-3
,然后1毛钱和Cents
变成<代码> -13 等。产生4个需要2个硬币。可以使用调试器诊断此问题,或者仅通过添加
printf(“ QUARTER =%d,Cents =%d \ n”,季度,Cents);
语句在调用计算>计算> counculate_dimes(美分)
。您应该使用
,而
循环。更一般而言,您应该避免do
/循环。它们很少是正确的工具。
这是一个修改版本:
但是,请注意,使用整数除法和剩余的方法有一个更简单的方法:
上述功能是一个很好的折衷...下面是所有操作的替代方法,所有操作都合并为单个表达式。您可以将其研究以获取信息,这是一个较小的示例,即在制作与以前版本非常相似的代码时更难以理解。
You use
do
/while
loops to compute the number of coins of each kind, hence you always count at least one coin of each kind, which is incorrect. For example if you have 2 cents to distribute, you will get 1 quarter andcents
will become-3
, then 1 dime andcents
becomes-13
, etc. resulting in 4 coins where 2 are needed.This problem could have been diagnosed using a debugger or simply by adding a
printf("quarters=%d, cents=%d\n", quarters, cents);
statement before callingcalculate_dimes(cents)
.You should use
while
loops instead. More generally, you should avoiddo
/while
loops. They are rarely the right tool.Here is a modified version:
Note however that there is a much simpler method using integer division and remainder:
The above function is a good compromise... below is an alternative with all the operations combined as a single expression. You can study it for information as an example of smaller being more difficult to understand while producing code very similar to the previous version.
您的
计算_*
功能都有一个错误。如果所提供的美分开始低于您在中测试的值{...}时(Cents&Gt; = value);
'怎么办?功能将返回1
。也就是说,他们总是会返回1
太多。它们都应重写为,而(Cents&Gt; = value){...}
Your
calculate_*
functions all have a bug. What if the supplied cents starts out lower than the value you test for in yourdo { ... } while(cents >= value);
? The functions would return1
. That is, they will always return1
too much. They should all be rewritten aswhile(cents >= value) { ... }