算法刷题记录 Day38

算法刷题记录 Day38

Date: 2024.04.04

lc 377. 组合总和IV

实际为排列问题。联想一下爬楼梯问题,若每次能爬1或2格,爬到第n阶的方法数,可以由n-1和n-2推出。该题同理,只是拓展了能爬的距离。

c++ 复制代码
class Solution {
public:
    int combinationSum4(vector<int>& nums, int target) {
        int n = nums.size();
        // dp[j]表示和为target的排列个数;
        vector<int> dp(target+1, 0);
        // 到target的方法数,可以由到target-nums[i]的方法数推出来。
        dp[0] = 1;

        for(int j=1; j<=target; j++){
            for(int i=0; i<n; i++){
                if(j >= nums[i] && dp[j-nums[i]] < INT_MAX - dp[j]){
                    dp[j] += dp[j-nums[i]];
                }
            }
        }
        return dp[target];
    }
};

lc 518. 零钱兑换II

c++ 复制代码
// 一维dp数组,组合问题
class Solution {
public:
    int change(int amount, vector<int>& coins) {
        int n = coins.size();
        // dp[j]表示组成金额为j的硬币组合数有几种;
        vector<int> dp(amount+1, 0);
        // d[j] = for(i) dp[j] += dp[j-nums[i]];
        // 初始化:
        dp[0] = 1;

        for(int i=0; i<n; i++){
            int tmp = coins[i];
            for(int j=0; j<=amount; j++){
                if(j >= tmp){
                    dp[j] += dp[j-tmp];
                }
            }
        }

        return dp[amount];
    }
};

// 二维dp数组,组合问题 
class Solution {
public:
    int change(int amount, vector<int>& coins) {
        int n = coins.size();
        // dp[i][j]表示从前i个硬币中,能得到总金额j的总组合数。
        vector<vector<int>> dp(n+1, vector<int>(amount+1, 0));
        // dp[i][j] = for(i) dp[i-1][j] += dp[i][j-coins[i]];
        // 初始化
        dp[0][0] = 1;
        for(int i=1; i<=n; i++){
            for(int j=0; j<=amount; j++){
                // cout<<"i:"<<i<<", j:"<<j<<endl;
                dp[i][j] = dp[i-1][j];
                if(j >= coins[i-1]){
                    dp[i][j] += dp[i][j-coins[i-1]];
                }
            }
        }
        return dp[n][amount];

    }
};
相关推荐
uesowys3 小时前
Apache Spark算法开发指导-Factorization machines classifier
人工智能·算法
TracyCoder1233 小时前
LeetCode Hot100(26/100)——24. 两两交换链表中的节点
leetcode·链表
季明洵3 小时前
C语言实现单链表
c语言·开发语言·数据结构·算法·链表
shandianchengzi3 小时前
【小白向】错位排列|图文解释公考常见题目错位排列的递推式Dn=(n-1)(Dn-2+Dn-1)推导方式
笔记·算法·公考·递推·排列·考公
I_LPL3 小时前
day26 代码随想录算法训练营 回溯专题5
算法·回溯·hot100·求职面试·n皇后·解数独
Yeats_Liao3 小时前
评估体系构建:基于自动化指标与人工打分的双重验证
运维·人工智能·深度学习·算法·机器学习·自动化
cpp_25013 小时前
P9586 「MXOI Round 2」游戏
数据结构·c++·算法·题解·洛谷
浅念-3 小时前
C语言编译与链接全流程:从源码到可执行程序的幕后之旅
c语言·开发语言·数据结构·经验分享·笔记·学习·算法
有时间要学习4 小时前
面试150——第五周
算法·深度优先
晚霞的不甘5 小时前
Flutter for OpenHarmony 可视化教学:A* 寻路算法的交互式演示
人工智能·算法·flutter·架构·开源·音视频