我用Java语言写了一个贪心算法小案例

贪心算法是一种在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望导致结果是最好或最优的算法。贪心算法在有最优子结构的问题中尤为有效。最优子结构的意思是局部最优解能决定全局最优解。

下面是一个使用Java实现的贪心算法示例,该算法解决了找零问题。给定一组硬币面值和一个总金额,我们需要找到最少的硬币数量来凑成这个总金额。

java 复制代码
import java.util.Arrays;

public class GreedyAlgorithm {
    public static void main(String[] args) {
        int[] coins = {1, 2, 5, 10, 20, 50, 100};
        int amount = 93;
        System.out.println("Minimum number of coins required: " + findMinCoins(coins, amount));
    }

    public static int findMinCoins(int[] coins, int amount) {
        Arrays.sort(coins); // 对硬币面值进行排序
        int count = 0;
        for (int i = coins.length - 1; i >= 0; i--) {
            while (amount >= coins[i]) {
                amount -= coins[i];
                count++;
            }
        }
        return count;
    }
}

在这个例子中,我们首先对硬币面值进行排序,然后从最大的硬币面值开始,尽可能多地使用该硬币,直到无法继续使用为止。然后我们继续尝试下一个较小的硬币面值,以此类推,直到凑齐总金额。最后返回使用的硬币数量。

相关推荐
影寂ldy1 分钟前
C# 多接口、同名冲突、显式实现、接口继承 完整笔记
java·笔记·c#
JAVA面经实录9172 分钟前
Spring Cloud Alibaba 微服务企业实战完整文档(架构+规范+调优+故障+源码)
java·运维·spring cloud·微服务
布局呆星2 分钟前
Spring Boot + JWT + Spring Security 认证授权实战:双角色、双 Token、方法级权限,一次讲透
java·开发语言
csdndeyeye2 分钟前
从Ctrl+C/V到一键填充:AI投简历工具实测
c语言·开发语言·自动化·秋招·ai助手·网申·ai投简历
大G的笔记本2 分钟前
生产级 Spring Boot 网关完整实现方案
java·笔记·gateway
LucianaiB4 分钟前
Swarm管理面板的多项目配置策略与模型别名机制的效率分析
java·服务器·前端
诸葛大钢铁5 分钟前
如何降低Word文件的体积?压缩Word文件的三种方法
开发语言·c#
小白学大数据6 分钟前
如何自动追踪 eBay 售价?Python 爬虫实战解析
开发语言·人工智能·爬虫·python
qq_2518364578 分钟前
基于Spring Boot的数据标注与质检系统设计与实现
java·spring boot·后端
莫逸风9 分钟前
【AgentScope】6.文件系统(Filesystem)详解
开发语言·windows·springai·agentscope·agnet