• 【代码随想录】day45


    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


    一、70爬楼梯 (进阶)

    去年春招面试被考过这个题,但当时没写出来。

    #include 
    #include 
    using namespace std;
    int main() {
        int n, m;
        cin >> n >> m;
        std::vector<int> dp(n + 1, 0);
        dp[0] = 1;
        for (int i = 1; i < n + 1; i ++) {
            for (int j = 1; j < m + 1; j ++) {
                if (i - j >= 0) {
                    dp[i] += dp[i-j];
                }
            }
        }
        cout << dp[n] << endl;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    二、322零钱兑换

    class Solution {
    public:
        int coinChange(vector<int>& coins, int amount) {
            vector<int> dp(amount + 1, INT_MAX - 1);
            dp[0] = 0;
            for (int j = coins[0]; j < amount + 1; j ++) {
                if (j % coins[0] == 0) {
                    dp[j] = j / coins[0];
                }
            }
            for (int i = 1; i < coins.size(); i ++) {
                if (coins[i] > amount) {
                    continue;
                }
                for (int j = 1; j < amount + 1; j ++) {
                    if (j >= coins[i]) {
                        dp[j] = min(dp[j], 1 + dp[j-coins[i]]);
                    }
                }
            }
            if (dp[amount] == INT_MAX - 1) return -1;
            return dp[amount];
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    初始化总是写不好啊。。。

    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 ++) {
                if (coins[i] > amount) {
                    continue;
                }
                for (int j = coins[i]; j < amount + 1; j ++) {
                    if (dp[j-coins[i]] != INT_MAX) {
                        dp[j] = min(dp[j], 1 + dp[j-coins[i]]);
                    }
                }
            }
            if (dp[amount] == INT_MAX) return -1;
            return dp[amount];
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    三、279完全平方数

    class Solution {
    public:
        int numSquares(int n) {
            //<=100
            vector<int> dp(n + 1, 0);
            for (int j = 1; j < n + 1; j ++) {
                dp[j] = j;
            }
            for (int i = 1; i <= 100 && i * i <= n; i ++) {
                for (int j = i*i; j < n + 1; j ++) {
                    dp[j] = min(dp[j], 1 + dp[j-i*i]);
                }
            }
            return dp[n];
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    修改初始化:

    class Solution {
    public:
        int numSquares(int n) {
            vector<int> dp(n + 1, INT_MAX);
            dp[0] = 0;
            for (int i = 1; i <= 100 && i * i <= n; i ++) {
                for (int j = i*i; j < n + 1; j ++) {
                    dp[j] = min(dp[j], 1 + dp[j-i*i]);
                }
            }
            return dp[n];
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
  • 相关阅读:
    Invalid bound statement (not found)解决方法总结
    Python 学习之路: 常用断言汇总
    RockyLinux安装MariaDB
    java字符编码总结
    天龙八部门派采集任务坐标
    学科核心素养
    数据发布!智驾域控前装搭载同比增长90.99%,哪些企业在领跑市场
    倾斜摄影技术构建图扑 WebGIS 智慧展馆
    CC1101 一款低功耗sub- 1ghz收发器芯片 适用于无线遥控智能家居
    【Hack The Box】linux练习-- Postman
  • 原文地址:https://blog.csdn.net/weixin_47041555/article/details/137843986