算法D45 | 动态规划7 | 70. 爬楼梯 (进阶) 322. 零钱兑换 279.完全平方数

news/2024/7/7 21:31:11

70. 爬楼梯 (进阶) 

这道题目 爬楼梯之前我们做过,这次再用完全背包的思路来分析一遍 

代码随想录

Python:

翻译成背包问题,即:在容量为n的背包里,装入重量为1/2的物品,可以重复利用物品,所以是完全背包问题。由于顺序在结果中重要,所以是排列问题,所以先遍历背包,后遍历物品。

class Solution:
    def climbStairs(self, n: int) -> int:
        dp = [0] * (n+1)
        dp[0] = 1
        for j in range(1,n+1):
            for i in [1, 2]:
                if j<i: continue
                dp[j] += dp[j-i]
        return dp[n]    

C++:

class Solution {
public:
    int climbStairs(int n) {
        vector<int> dp(n+1, 0);
        dp[0] = 1;
        for (int j=1; j<=n; j++) {
            for (int i=1; i<=2; i++) {
                if (j<i) continue;
                dp[j] += dp[j-i];
            }
        }
        return dp[n];
    }
};

322. 零钱兑换  

如果求组合数就是外层for循环遍历物品,内层for遍历背包。

如果求排列数就是外层for遍历背包,内层for循环遍历物品。

这句话结合本题 大家要好好理解。

视频讲解:动态规划之完全背包,装满背包最少的物品件数是多少?| LeetCode:322.零钱兑换_哔哩哔哩_bilibili

代码随想录

Python二维:

第一遍推的,代码稍微冗余,逻辑差不多,模板还是模板啊。

class Solution:
    def coinChange(self, coins: List[int], amount: int) -> int:
        if amount==0: return 0
        coins.sort(reverse=True)
        m = len(coins)
        dp = [[-1]*amount for _ in range(m+1)]
        for i in range(1, m+1):
            c = coins[i-1]
            for j in range(c-1, amount):
                if dp[i-1][j] != -1 and dp[i][j-c] != -1:
                    dp[i][j] = min(dp[i-1][j], dp[i][j-c]+1)
                elif dp[i-1][j] != -1:
                    dp[i][j] = dp[i-1][j]
                elif dp[i][j-c] != -1:
                    dp[i][j] = dp[i][j-c] + 1
                elif (j+1) % c == 0:
                    dp[i][j] = (j+1)//c
        return dp[-1][-1]

Python一维:

优化成一维格式:

class Solution:
    def coinChange(self, coins: List[int], amount: int) -> int:
        dp = [float('inf')] * (amount+1)
        dp[0] = 0
        for c in coins:
            for j in range(c, amount+1):
                if dp[j-c]!=float('inf'):
                    dp[j] = min(dp[j-c]+1, dp[j])
        if dp[amount]==float('inf'): return -1
        return dp[amount]

C++一维:

class Solution {
public:
    int coinChange(vector<int>& coins, int amount) {
        vector<int> dp(amount+1, INT_MAX);
        dp[0] = 0;
        for (int i=0; i<coins.size(); i++) {
            for (int j=coins[i]; j<=amount; j++) {
                if (dp[j-coins[i]]!=INT_MAX) {
                    dp[j] = min(dp[j], dp[j-coins[i]]+1);
                }
            }
        }
        if (dp[amount]==INT_MAX) return -1;
        return dp[amount];
    }
};

279.完全平方数  

本题 和 322. 零钱兑换 基本是一样的,大家先自己尝试做一做 

视频讲解:动态规划之完全背包,换汤不换药!| LeetCode:279.完全平方数_哔哩哔哩_bilibili

代码随想录

Python:

和322类似的,把完全平方数当成硬币,放进大小为n的包里,硬币个数最少的方案。

class Solution:
    def numSquares(self, n: int) -> int:
        m = int(n**0.5)
        dp = list(range(n+1))
        for i in range(1, m+1):
            for j in range(i**2, n+1):
                dp[j] = min(dp[j-i**2]+1, dp[j])
        return dp[n]

C++:

优化一下卡哥的版本,遍历i到n的sqrt的int即可。

class Solution {
public:
    int numSquares(int n) {
        vector<int> dp(n+1, 0);
        for (int i=0; i<=n; i++) dp[i] = i;
        int m = int(sqrt(n));
        for (int i=1; i<=m; i++) {
            for (int j=i*i; j<=n; j++) {
                dp[j] = min(dp[j], dp[j-i*i]+1);
            }
        }
        return dp[n];
    }
};


http://lihuaxi.xjx100.cn/news/2090395.html

相关文章

RabbitMQ学习笔记——声明队列和交换机的方式(Config配置方式)

1.config配置文件方式 Config配置这种方式的缺点就是队列绑定交换机时设置的routingKey&#xff0c;需要一个个的创建方法去绑定&#xff0c;如下就需要绑定两次&#xff0c;太麻烦了&#xff0c;如下&#xff1a;

AOP-注解实现-记录日志到数据库

概念解释 AOP&#xff1a;Aspect Oriented Programming Aspect&#xff1a;方面Oriented&#xff1a;面向…的Programming编程 之前我对模块化编程的认识&#xff0c;主要是局限在布局结构、目录结构上。比如Vue的template模板。 对方法的模块化编程&#xff0c;我之前的认识…

Ansible运维自动化

什么是 Ansible&#xff1f; Ansible 是一款开源的自动化工具&#xff0c;由 Red Hat 公司推出。它基于 Python 编写&#xff0c;旨在简化系统配置、部署和管理。Ansible 的核心思想是使用简单易懂的 YAML 格式的 Playbooks 来描述自动化任务。与其他自动化工具相比&#xff0…

快手,得物,蓝月亮,蓝禾,奇安信,三七互娱,顺丰,康冠科技,金证科技24春招内推

快手&#xff0c;得物&#xff0c;蓝月亮&#xff0c;蓝禾&#xff0c;奇安信&#xff0c;三七互娱&#xff0c;顺丰&#xff0c;康冠科技&#xff0c;金证科技24春招内推 ①得物 【岗位】技术&#xff0c;设计&#xff0c;供应链&#xff0c;风控&#xff0c;产品&#xff0c;…

使用动态ip上网稳定吗?

随着互联网的普及&#xff0c;越来越多的用户开始关注网络隐私和安全。代理IP服务应运而生&#xff0c;为广大用户提供了一个有效的解决方案。许多用户在使用代理IP时可能会担心其稳定性问题&#xff0c;本文将为您详细解答。 一、什么是动态IP&#xff1f; 动态IP是指由DHCP…

进制转换概念及例题

进制转换是一种数字表示方法之间的转换。在计算机科学和数学中,常见的进制包括十进制(基数为 10)、二进制(基数为 2)、八进制(基数为 8)和十六进制(基数为 16)。 进制转换的基本概念是将一个数从一种进制表示转换为另一种进制表示。例如,将十进制数 15 转换为二进制…

Mybatis-plus手写SQL如何使用条件构造器和分页

Mybatis-plus手写SQL如何使用条件构造器和分页插件 前言&#xff1a;在使用mybatis-plus过程中&#xff0c;使用条件构造器和分页插件非常效率的提升开发速度&#xff0c;但有些业务需要使用连表查询&#xff0c;此时还想使用条件构造器和使用分页时应该如何操作呢&#xff1f…

多媒体技术2-颜色空间

颜色空间是一种用于表示和描述颜色的数学模型。它是由颜色分量和坐标系组成的。常见的颜色空间有RGB、CMYK、HSV等。 RGB颜色空间&#xff1a;RGB是红、绿、蓝三个颜色分量的缩写。在RGB颜色空间中&#xff0c;每个颜色分量的取值范围是0到255&#xff0c;表示了红、绿、蓝三个…