超市找零方案

    实现超市的找零方案,只需输入需要补给顾客的金额,然后通过程序计算该金额可以由哪些金额的人民币组成。

 

分析:

    人民币有100、50、10、5、1、0.5、0.1 等多种面额(单位为元)。

1、定义面额值的数组,为方便计算,将数额乘以100,数组如下:

    pervalue = [10000, 5000, 1000, 500, 100, 50, 10]

2、定义面额张数的数组,数组长度为面额值数组pervalue的长度,数组如下:

    num = [0, 0, 0, 0, 0, 0, 0]

3、输入金额:money,定义标识 flag = 0;

4、当 money > 0时,如果 money 大于等于 pervalue[flag],则将 money 减去当前的面额值 pervalue[flag],同时 num[flag] 的值加一,表示当前面额的张数加一;

5、如果money 小于 pervalue[flag],则直接将 flag 加一,

6、重复第4、5步操作,直到 money <= 0,结束循环。

7、如此一来,num 数组的值便是 pervalue 数组的面额值所对应的张数。

 

代码实现如下:

let pervalue = [10000, 5000, 1000, 500, 100, 50, 10];
let MAXN = pervalue.length;

let num = [];
for (let i=0; i<MAXN; ++i) {
    num[i] = 0;
}

function exchange(money) {
    let flag = 0;
    while (money > 0) {
        if (money >= pervalue[flag]) {
            money -= pervalue[flag];
            ++num[flag];
        } else {
            ++flag;
        }
    }
}

let money = 123.8;
emoney = parseInt(100 * money)

exchange(emoney);

console.log(money + "元零钱的组成为:")
for(let k=0; k<MAXN; ++k) {
    if (num[k] > 0) {
        console.log(pervalue[k] / 100 + " 元 : " + num[k] + " 张")
    }
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这里是Java的最少硬币找零方案(动态规划)的代码: ```java public class MinimumCoinsChange { public static void main(String[] args) { int[] coins = {1, 2, 5, 10, 20, 50, 100, 200}; int amount = 286; int[] minCoins = new int[amount+1]; Arrays.fill(minCoins, Integer.MAX_VALUE); minCoins[0] = 0; for (int coin : coins) { for (int j = coin; j <= amount; j++) { if (minCoins[j-coin] != Integer.MAX_VALUE) { minCoins[j] = Math.min(minCoins[j], minCoins[j-coin] + 1); } } } System.out.println("Minimum coins required to make " + amount + " cents is: " + minCoins[amount]); System.out.print("Coins used are: "); int i = amount; while (i > 0) { for (int j = coins.length-1; j >= 0; j--) { if (i >= coins[j] && minCoins[i-coins[j]] == minCoins[i]-1) { System.out.print(coins[j] + " "); i -= coins[j]; break; } } } } } ``` 这个程序的输出结果将会是: ``` Minimum coins required to make 286 cents is: 7 Coins used are: 200 50 20 10 5 1 ``` 其中,`coins`数组定义了可用的硬币面额,`amount`变量表示需要找零的总金额。在程序中,我们首先创建了一个大小为`amount+1`的`minCoins`数组,并将其所有元素初始化为`Integer.MAX_VALUE`。然后,我们遍历每种硬币面额,并且对于每个面额,我们遍历`minCoins`数组中的每个位置`j`。如果`j-coin`位置的最小硬币数不是`Integer.MAX_VALUE`,那么我们更新`minCoins[j]`为`minCoins[j-coin] + 1`。这个过程确保了我们最终得到的`minCoins`数组中的每个元素都是最小的硬币数。 在找到最小硬币数之后,我们使用一个循环来找出用于找零的每个硬币。我们从`amount`开始,对于每个可用的硬币面额,如果当前金额大于等于这个面额,并且`minCoins[i-coins[j]]`等于`minCoins[i]-1`,那么我们就输出这个硬币面额,并将`i`减去这个面额。这个过程一直持续到`i`变成了0,即我们已经找完了所有的硬币。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值