java代码实现贪心算法深入简出

贪心算法

贪心算法是一种基于贪心思想的算法,它在每一步选择中都采取当前状态下最优的选择,从而希望最终得到全局最优解。

下面是使用Java代码实现贪心算法的例子:

假设我们有一堆硬币,它们的面值分别为1元、5元、10元、50元、100元,现在要用尽量少的硬币凑出36元。

1. 首先,我们需要定义一个数组,用于存储硬币的面值:

int[] coins = {1, 5, 10, 50, 100}; 

2. 接着,我们定义一个变量sum,用于记录当前已经凑出的金额。初始化sum为0:

int sum = 0; 

3. 我们还需要定义一个变量count,用于记录已经使用的硬币数量。初始化count为0:

int count = 0; 

4. 接下来,我们可以使用一个while循环来不断地选取当前状态下面值最大的硬币,并将它加入到已选硬币集合中:

while (sum < 36) {
    for (int i = coins.length - 1; i >= 0; i--) {
        if (sum + coins[i] <= 36) {
            sum += coins[i];
            count++;
            break;
        }
    }
}

5. 最后,我们输出所选硬币的数量:

System.out.println("使用硬币数量为:" + count);

完整代码如下:

public static void main(String[] args) {
    int[] coins = {1, 5, 10, 50, 100};
    int sum = 0;
    int count = 0;
    while (sum < 36) {
        for (int i = coins.length - 1; i >= 0; i--) {
            if (sum + coins[i] <= 36) {
                sum += coins[i];
                count++;
                break;
            }
        }
    }
    System.out.println("使用硬币数量为:" + count);
}

以上代码实现了一个简单的贪心算法,它通过不断地选取面值最大的硬币来凑出指定金额,以达到尽可能少地使用硬币的目的。在实际应用中,我们可以根据具体情况设计更加复杂的贪心算法,以求得更好的效果。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
田忌赛马是一个经典的策略问题,源自中国古代的故事,描述了田忌通过巧妙安排自己的马匹顺序,以战胜强大的对手。在Java实现田忌赛马的贪心算法,可以通过动态规划的方法来解决。这里我们不涉及贪心算法,因为田忌赛马更适合用回溯法或递推策略,但我会简单解释如何用回溯法来模拟这个过程。 首先,我们需要定义三个等级的马(A、B、C),每个等级有若干匹马,每匹马有不同的能力(比如速度)。假设我们有一个二维数组`matrix`表示三匹马之间的胜负关系: ```java int[][] matrix = { {0, 1, 2}, // A级马胜B级马,平C级马 {1, 0, 1}, // B级马胜C级马,平A级马 {2, 1, 0} // C级马胜A级马,平B级马 }; ``` 然后,我们可以使用回溯法来尝试所有可能的马匹排列: ```java class Racer { int horseLevel; } List<Racer> horses = Arrays.asList(new Racer[]{new Racer{horseLevel=0}, new Racer{horseLevel=1}, new Racer{horseLevel=2}}; boolean[] used = new boolean; // 标记马是否已使用 void solve(int aPos, int bPos, int cPos) { if (aPos == 3 && bPos == 3 && cPos == 3) { // 找到一个解 System.out.println("田忌的顺序: " + horses.get(aPos).horseLevel + ", " + horses.get(bPos).horseLevel + ", " + horses.get(cPos).horseLevel); return; } for (int i = 0; i < 3; i++) { if (!used[i]) { used[i] = true; // 尝试将当前马放到这个位置 solve(aPos + 1, bPos, cPos); // 前面的马换到下一个位置 used[i] = false; // 如果没有找到解决方案,恢复当前马的位置 } } } solve(0, 0, 0); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我的头发哪去了

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值