ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

leetcode完全背包-518.零钱兑换II

2021-12-27 11:04:34  阅读:177  来源: 互联网

标签:背包 int coins param II 518 amount leetcode dp


完全背包和01背包的区别
01背包,每个物品只有一件,只能放or不妨
完全背包,每个物品无线,可放,可不妨


package dp.完全背包;

/**
 * 518. 零钱兑换 II
 * 给你一个整数数组 coins 表示不同面额的硬币,另给一个整数 amount 表示总金额。
 * <p>
 * 请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额,返回 0 。
 * <p>
 * 假设每一种面额的硬币有无限个。
 * <p>
 * 题目数据保证结果符合 32 位带符号整数。
 * <p>
 * <p>
 * <p>
 * 示例 1:
 * <p>
 * 输入:amount = 5, coins = [1, 2, 5]
 * 输出:4
 * 解释:有四种方式可以凑成总金额:
 * 5=5
 * 5=2+2+1
 * 5=2+1+1+1
 * 5=1+1+1+1+1
 * 示例 2:
 * <p>
 * 输入:amount = 3, coins = [2]
 * 输出:0
 * 解释:只用面额 2 的硬币不能凑成总金额 3 。
 * 示例 3:
 * <p>
 * 输入:amount = 10, coins = [10]
 * 输出:1
 * <p>
 * <p>
 * 提示:
 * <p>
 * 1 <= coins.length <= 300
 * 1 <= coins[i] <= 5000
 * coins 中的所有值 互不相同
 * 0 <= amount <= 5000
 */
public class change {
    /**
     * 完全背包问题,状态俩种,背包容量,状态选择(装进背包,不装背包)
     * 状态转移方程
     * <p>
     * if(j-coins[i-1]>0;
     * dp[i][j] = dp[i-1]j + dp[i-1][j-coins[i-1]]
     * else
     * dp[i][j] = dp[i-1][j] 不装
     *
     * @param amount
     * @param coins
     * @return
     */
    public static int change(int amount, int[] coins) {
        int n = coins.length;
        int[][] dp = new int[n + 1][amount + 1];
        for (int i = 0; i <= n; i++) {
            dp[i][0] = 1;
        }
        for (int i = 1; i <= n; i++) {
            for (int j = 1; j <= amount; j++) {
                if (j - coins[i - 1] >= 0) {
                    dp[i][j] = dp[i - 1][j] + dp[i][j - coins[i - 1]];
                } else {
                    dp[i][j] = dp[i - 1][j];
                }
            }
        }
        return dp[n][amount];
    }

    /**
     * dp 只和 dp[i] 和 dp[i-1]的状态有关
     * @param amount
     * @param coins
     * @return
     */
    static int change2(int amount, int[] coins) {
        int n = coins.length;
        int[] dp = new int[amount + 1];
            dp[0] = 1;
        for (int i = 1; i <= n; i++) {
            for (int j = 1; j <= amount; j++) {
                if (j - coins[i - 1] >= 0) {
                   dp[j] = dp[j]+ dp[j-coins[i-1]];
                }
            }
        }
        return dp[amount];
    }

    public static void main(String[] args) {
        int amount = 5;
        int[] coins = {1, 2, 5};
//        System.out.println(change(amount, coins));
        System.out.println(change2(amount, coins));
    }
}

标签:背包,int,coins,param,II,518,amount,leetcode,dp
来源: https://www.cnblogs.com/xiaoshahai/p/15735427.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有