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

【Hot100】LeetCode—322. 零钱兑换

目录

  • 1- 思路
    • 动态规划
  • 2- 实现
    • 322. 零钱兑换——题解思路
  • 3- ACM 实现


  • 原题链接:322. 零钱兑换

1- 思路

动态规划

动规五部曲

  • 1- 定义 dp 数组确定含义
    • dp[j] 代表凑到金钱为 j 的最少硬币个数
  • 2- 递推公式
    • dp[j] = Math.min(dp[j],dp[amount-]+1)
  • 3- 初始化
    • dp[0] = 0
    • 其他全部初始化为 max
  • 4- 遍历顺序
    • 先遍历物品,再遍历背包
    • 递推过程需要判断 dp[j - coins[i]] != max

2- 实现

322. 零钱兑换——题解思路

在这里插入图片描述

class Solution {
    public int coinChange(int[] coins, int amount) {
        // 1. 定义 dp 数组
        // dp[j] 代表凑到金钱为 j 的最少硬币个数
        int[] dp = new int[amount+1];

        // 2.递推公式
        // dp[j] = Math.min(dp[j],dp[amount-]+1)
        
        // 初始化
        dp[0] = 0;
        int max = Integer.MAX_VALUE;
        for(int i = 1 ; i <= amount;i++){
            dp[i] = max;
        }

        // 4. 遍历顺序
        // 物品
        
        for(int i = 0 ; i < coins.length;i++){
            for(int j = coins[i] ; j <= amount ; j++){
                if(dp[j - coins[i]] != max){
                    dp[j] = Math.min(dp[j],dp[j-coins[i]]+1);
                }
            }
        }

        if(dp[amount]==max){
            return -1;
        }
        return dp[amount];
    }
}

3- ACM 实现

public class minCoins {


    public static int minCoins(int[] nums,int target){
        // 定义 dp
        int[] dp = new int[target+1];

        // 2. 递推公式
        // dp[j] = Math.min(dp[j],dp[j-coins[i]]+1);

        // 3.初始化
        dp[0] = 0;
        int max = Integer.MAX_VALUE;
        for(int i = 1 ; i <= target;i++){
            dp[i] = max;
        }

        // 4.遍历顺序
        for(int i = 0 ; i <nums.length;i++){
            for(int j = nums[i]; j<=target;j++){
                if(dp[j-nums[i]] != max){
                    dp[j] = Math.min(dp[j],dp[j-nums[i]]+1);
                }
            }
        }
        if(dp[target]==max){
            return -1;
        }
        return dp[target];
    }



    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String input = sc.nextLine();
        String[] parts = input.split(" ");
        int[] nums = new int[parts.length];
        for(int i = 0 ; i < parts.length;i++){
            nums[i] = Integer.parseInt(parts[i]);
        }
        int target = sc.nextInt();
        System.out.println("结果是"+minCoins(nums,target));

    }
}

http://www.kler.cn/a/300010.html

相关文章:

  • 深入理解三高架构:高可用性、高性能、高扩展性的最佳实践
  • Odoo免费开源ERP最佳业务实践:生产管理
  • 【RabbitMQ 消息丢失常见情况分析】
  • 图谱之前端关系应用
  • Selenium配合Cookies实现网页免登录
  • 《安富莱嵌入式周报》第349期:VSCode正式支持Matlab调试,DIY录音室级麦克风,开源流体吊坠,物联网在军工领域的应用,Unicode字符压缩解压
  • 关于武汉芯景科技有限公司的IIC缓冲器芯片XJ4307开发指南(兼容LTC4307)
  • 网络安全(sql注入)
  • DS18B20的C语言驱动
  • 基础算法(2)——滑动窗口
  • 针对中小企业数智化需求,新华三重磅发布 SMB 系列新品
  • 某仿soul欲音社交系统存在任意文件读取漏洞
  • 重修设计模式-结构型-代理模式
  • 音视频入门基础:WAV专题(9)——FFmpeg源码中计算WAV音频文件每个packet的duration和duration_time的实现
  • flinkcdc 问题记录篇章
  • 只有IP地址没有域名怎么实现HTTPS访问?
  • 【高级编程】Java IO流(补)序列化 反序列化
  • Pyspark下操作dataframe方法(1)
  • eNUM 原理概述(VoNR VoLTE适用) eNUM 报文解析
  • Vue2使用Vue CLI学习笔记
  • python 实现kadanes卡达内斯算法
  • 基于协同过滤算法+SpringBoot+Vue+MySQL的商品推荐系统
  • 人工智能帮你管理 ADHD 的7种方法
  • [Git使用] 实战技巧
  • 建造者模式builder
  • 九月五日(k8s配置)