某企业发放奖金,请你编写程序,帮助出纳员用最少的纸币发放奖金。其中奖金精确到元。 注:纸币面额为 100 元、50 元、20 元、10 元、5 元、2 元和 1 元。 输入格式 金额 (以元为单位,小于 10000 的整数) 输出格式 按钞票面额由大到小的顺序输出各种钞票的张数(参见输出样例) 输入样例 5382 输出样例 100元: 53张 50元: 1张 20元: 1张 10元: 1张 5元: 0张 2元: 1张 1元: 0张
时间: 2023-05-31 15:06:53 浏览: 167
分析:由于要用最少的纸币发放奖金,因此可以贪心地思考。每次尽量使用面额最大的钞票,直到奖金金额为0为止。具体实现可以使用一个数组存储每种面额的钞票数量,从大到小遍历每种面额,每次尽量取用该面额的钞票,更新奖金金额和数组中该面额的钞票数量。最后输出数组中每种面额的钞票数量。需要注意的是,在输出钞票数量时,如果该面额的钞票数量为0,不需要输出。
相关问题
某企业发放奖金,请你编写程序,帮助出纳员用最少的纸币发放奖金。其中奖金精确到元。 注:纸币面额为 100 元、50 元、20 元、10 元、5 元、2 元和 1 元
这道题目需要用到贪心算法,即每次尽量用面值大的纸币来发放奖金。具体步骤如下:
1. 读入奖金金额。
2. 计算100元纸币的张数,即奖金金额除以100。
3. 计算50元纸币的张数,即奖金金额对100取余再除以50。
4. 计算20元纸币的张数,即奖金金额对100取余再对50取余再除以20。
5. 计算10元纸币的张数,即奖金金额对100取余再对50取余再对20取余再除以10。
6. 计算5元纸币的张数,即奖金金额对100取余再对50取余再对20取余再对10取余再除以5。
7. 计算2元纸币的张数,即奖金金额对100取余再对50取余再对20取余再对10取余再对5取余再除以2。
8. 计算1元纸币的张数,即奖金金额对100取余再对50取余再对20取余再对10取余再对5取余再对2取余。
下面是代码实现:
```
#include <stdio.h>
int main() {
int money;
scanf("%d", &money);
printf("100元:%3d张\n", money / 100);
printf(" 50元:%3d张\n", money % 100 / 50);
printf(" 20元:%3d张\n", money % 100 % 50 / 20);
printf(" 10元:%3d张\n", money % 100 % 50 % 20 / 10);
printf(" 5元:%3d张\n", money % 100 % 50 % 20 % 10 / 5);
printf(" 2元:%3d张\n", money % 100 % 50 % 20 % 10 % 5 / 2);
printf(" 1元:%3d张\n", money % 100 % 50 % 20 % 10 % 5 % 2 / 1);
return 0;
}
```
某企业发放奖金,请你编写程序,帮助出纳员用最少的纸币发放奖金。其中奖金精确到元。注:纸币面额为 100 元、50 元、20 元、10 元、5 元、2 元和 1 元。
可以的,这是一个经典的纸币找零问题。以下是一个可能的解法:
首先,将需要找零的金额作为输入传递给程序。然后,建立一个数组,表示每种面额纸币的数量。假设初始值均为0,表示当前没有任何纸币。
接着,从面额最大的纸币开始,一个一个地检查是否可以用该面额的纸币找零。如果可以,就尽可能用该面额的纸币找零,并且减少该面额纸币的数量。
重复上述步骤,直到所有的纸币都被检查过为止。最终,输出所用的纸币数量即可。
下面是一个示例程序,供参考:
```python
def find_changes(amount):
denominations = [100, 50, 20, 10, 5, 2, 1]
counts = [0] * len(denominations)
for i, d in enumerate(denominations):
while amount >= d:
counts[i] += 1
amount -= d
return counts
```
例如,如果奖金为 1234 元,就调用函数 `find_changes(1234)`,会返回一个包含 7 个整数的列表,表示需要 10 张 100 元、2 张 10 元、1 张 10 元、2 张 2 元,没有其它面额的纸币。
阅读全文