当前位置: 首页 > article >正文

后端开发刷题 | 兑换零钱(动态规划)

描述

给定数组arr,arr中所有的值都为正整数且不重复。每个值代表一种面值的货币,每种面值的货币可以使用任意张,再给定一个aim,代表要找的钱数,求组成aim的最少货币数。

如果无解,请返回-1.

数据范围:数组大小满足0≤n≤10000 , 数组中每个数字都满足 0<val≤10000,0≤aim≤5000

要求:时间复杂度 O(n×aim),空间复杂度 O(aim)。

示例1

输入:

[5,2,3],20

返回值:

4

示例2

输入:

[5,2,3],0

返回值:

0

示例3

输入:

[3,5],2

返回值:

-1

思路分析:

  1. 初始化变量
    • Max = aim + 1:定义了一个全局最大值,用于初始化dp数组。这个值被设置为aim + 1,是因为如果dp数组中的某个值保持为Max,则表示无法用给定的硬币组成该金额。
    • dp = new int[aim + 1]:定义了一个dp数组,其中dp[i]表示组成金额i所需的最少硬币数。数组大小为aim + 1,因为需要包括目标金额本身。
    • Arrays.fill(dp, Max):将dp数组的所有元素初始化为Max,即无法组成该金额的状态。
    • dp[0] = 0:初始化dp数组的第一个元素为0,表示组成金额为0所需的最少硬币数为0。
  2. 动态规划过程
    • 外层循环遍历目标金额i(从1到aim),表示当前要尝试组成的金额。
    • 内层循环遍历硬币数组arr,检查每个硬币的面值。
    • 如果当前硬币的面值arr[j]小于等于当前要组成的金额i,则尝试使用这枚硬币。通过dp[i] = Math.min(dp[i], dp[i-arr[j]] + 1)更新dp[i]的值。这里dp[i-arr[j]] + 1表示使用了一枚面值为arr[j]的硬币后,还需要多少硬币来组成剩余的金额i-arr[j],然后加1表示当前使用的这枚硬币。
  3. 返回结果
    • 最后,dp[aim]存储了组成目标金额aim所需的最少硬币数。但是,如果dp[aim]仍然是初始化的Max值,说明无法用给定的硬币组成目标金额,因此返回-1。否则,返回dp[aim]

代码:

import java.util.*;


public class Solution {
    /**
     
     * 最少货币数
     * @param arr int整型一维数组 the array
     * @param aim int整型 the target
     * @return int整型
     */
    public int minMoney (int[] arr, int aim) {
        //定义一个全局最大值
        int max=aim+1;
        int[] dp=new int[aim+1];
        Arrays.fill(dp,max);//初始化数组
        dp[0]=0;
        for(int i=1;i<=aim;i++){
            for(int j=0;j<arr.length;j++){
                if(arr[j]<=i){
                    dp[i]=Math.min(dp[i],dp[i-arr[j]]+1);
                }
            }
        }
        return dp[aim]>aim?-1:dp[aim];
    }
}


http://www.kler.cn/news/306993.html

相关文章:

  • Prometheus+grafana+kafka_exporter监控kafka运行情况
  • 【Scala入门学习】基本数据类型和变量声明
  • [Mamba_4]LMa-UNet
  • 95、k8s之rancher可视化
  • STM32之FMC—扩展外部 SDRAM
  • Neo4j入门案例:三星堆
  • 基于Springboot的校园防疫管理系统的设计与实现
  • 【爬虫软件】小红书按关键词批量采集笔记,含笔记正文、转评赞藏等!
  • Linux whereis和which的区别
  • 光伏板热斑缺陷检测数据集
  • RocketMQ出现The broker does not support consumer to filter message by SQL92
  • JUC学习笔记(三)
  • 计算机网络(六) —— http协议详解
  • 黑马十天精通MySQL知识点
  • 【佳学基因检测】在EXCEL中,如何获取A列的第9-29个字符,将其填入另一列中
  • 华为ensp中vlan与静态路由技术的实现
  • 『功能项目』伤害数字UI显示【53】
  • 基于SpringBoot+Vue+MySQL的校园健康驿站管理系统
  • Baumer工业相机堡盟工业相机如何通过NEOAPI SDK获取相机当前数据吞吐量(Python)
  • Java | Leetcode Java题解之第406题根据身高重建队列
  • ARACom Proxy Class API 概念
  • 鸿蒙介绍、鸿蒙编程环境、基本组件、页面跳转学习
  • CPU 和 GPU:为什么GPU更适合深度学习?
  • PostgreSQL 日常SQL语句查询记录
  • linux网络编程——UDP编程
  • 预测日前电价:回顾最先进的算法、最佳实践和公开基准——阅读笔记
  • Linux FTP服务问题排查
  • 数据技术革命来袭!从仓库到飞轮,企业数字化的终极进化!
  • 机房运维工作的核心:确保系统稳定与高效
  • java计算机毕设课设—电子政务网系统(附源码、文章、相关截图、部署视频)