背包问题—动态规划

news2025/1/13 13:32:39

01背包问题:没有物品(元素)只能选择1次

【模板】01背包_牛客题霸_牛客网 (nowcoder.com)

#include <array>
#include <cstring>
#include <iostream>
#include<vector>
using namespace std;
int n,V;
int dp[1001][1001];

int main() {
    cin>>n>>V;
    vector<int> volume(n,0);
    vector<int> value(n,0);
    for(int i=0;i<n;i++){
        cin>>volume[i];
        cin>>value[i];
    }
    for(int i=1;i<=n;i++){
        for(int j=0;j<=V;j++){//j从0开始,要满足后面的填表
            dp[i][j]=dp[i-1][j];
            if(j-volume[i-1]>=0)//j-volume[i]==0:表示只用i这个就装满背包
            dp[i][j]=max(dp[i][j],dp[i-1][j-volume[i-1]]+value[i-1]);
        }
    }
    cout<<dp[n][V]<<endl;
    memset(dp, 0, sizeof(dp));
    //用-1表示不可能恰好装满的状态
    for(int i=1;i<=V;i++) dp[0][i]=-1;
    for(int i=1;i<=n;i++){
        for(int j=0;j<=V;j++){
            dp[i][j]=dp[i-1][j];
            if(j-volume[i-1]>=0&&dp[i-1][j-volume[i-1]]!=-1)
                dp[i][j]=max(dp[i][j],dp[i-1][j-volume[i-1]]+value[i-1]);
        }
    }
    cout<<(dp[n][V]==-1?0:dp[n][V])<<endl;
}   

// 64 位输出请用 printf("%lld")

416. 分割等和子集 - 力扣(LeetCode)

class Solution {
public:
    bool canPartition(vector<int>& nums) {
        int n=nums.size();
        int sum=0;
        for(int i=0;i<n;i++){
            sum+=nums[i];
        }
        if(sum%2==1) return false;
        int volume=sum/2;
        vector<vector<bool>> dp(n+1,vector<bool>(volume+1,false));
        dp[0][0]=true;
        for(int i=1;i<=n;i++){
            for(int j=0;j<=volume;j++){
                dp[i][j]=dp[i-1][j];
                if(j>=nums[i-1])
                dp[i][j]=dp[i-1][j]||dp[i-1][j-nums[i-1]];
            }
        }
        return dp[n][volume];
    }   
};

494. 目标和 - 力扣(LeetCode)

class Solution {
public:
    int findTargetSumWays(vector<int>& nums, int target) {
        int sum=0; int n=nums.size();
        for(int i=0;i<n;i++){
            sum+=nums[i];
        } 
        int _target=(sum+target)/2;
        if(_target<0||(sum+target)%2==1) return 0;//_target<0,没有情况
        vector<vector<int>> dp(n+1,vector<int>(_target+1,0));//状态表示,在1~i中选择元素,1<=i<=n,一共有多少种选择可以达到_target
        dp[0][0]=1;
        for(int i=1;i<=n;i++){
            for(int j=0;j<=_target;j++){
                dp[i][j]=dp[i-1][j];
                if(j-nums[i-1]>=0){//法则2,下标有算法实际操作的数映射正确
                    dp[i][j]+=dp[i-1][j-nums[i-1]];
                }
            }
        }
        return dp[n][_target];
    }
};

1049. 最后一块石头的重量 II - 力扣(LeetCode)

class Solution {
public:
    int lastStoneWeightII(vector<int>& stones) {
        int n=stones.size(); int sum=0;
        for(int &val:stones){
            sum+=val;
        }
        int aim=sum/2;
        vector<vector<int>> dp(n+1,vector<int>(aim+1,0));
        for(int i=1;i<=n;i++){
            for(int j=0;j<=aim;j++){
                dp[i][j]=dp[i-1][j];
                if(j>=stones[i-1]){
                    dp[i][j]=max(dp[i][j],dp[i-1][j-stones[i-1]]+stones[i-1]);
                }
            }
        }
        return sum-2*dp[n][aim];
    }
};

完全背包,物品(元素)个数有无限个 

【模板】完全背包_牛客题霸_牛客网 (nowcoder.com)

#include <iostream>
#include <iterator>
#include <new>
using namespace std;
#include <vector>
int main() {
    int n,V;
    cin>>n>>V;
    vector<int> volume(n+1,0);
    vector<int> value(n+1,0);
    for(int i=1;i<=n;i++){
        cin>>volume[i]>>value[i];
    }
    vector<vector<int>> dp(n+1,vector<int>(V+1,0));
    for(int i=1;i<=n;i++){
        for(int j=0;j<=V;j++){
            dp[i][j]=dp[i-1][j];
            if(j>=volume[i]){
                dp[i][j]=max(dp[i-1][j],dp[i][j-volume[i]]+value[i]);
            }
        }
    }
    cout<<dp[n][V]<<endl;
    dp[0][0]=0;
    for(int i=1;i<=V;i++) dp[0][i]=-1;
    for(int i=1;i<=n;i++){
        for(int j=0;j<=V;j++){
            dp[i][j]=dp[i-1][j];
            if(j>=volume[i]&&dp[i][j-volume[i]]!=-1){
                dp[i][j]=max(dp[i-1][j],dp[i][j-volume[i]]+value[i]);
            }
        }
    }
    cout<<(dp[n][V]==-1?0:dp[n][V]);

    return 0;
}
// 64 位输出请用 printf("%lld")

322. 零钱兑换 - 力扣(LeetCode)

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

518. 零钱兑换 II - 力扣(LeetCode)

class Solution {
public:
    int change(int amount, vector<int>& coins) {
        int n=coins.size();
        vector<vector<int>> dp(n+1,vector<int>(amount+1,0));
        dp[0][0]=1; 
        for(int i=1;i<=amount;i++) dp[0][i]=0;
        for(int i=1;i<=n;i++){
            for(int j=0;j<=amount;j++){
                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];
    }
};

279. 完全平方数 - 力扣(LeetCode)

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

474. 一和零 - 力扣(LeetCode)

class Solution {
public:
    int findMaxForm(vector<string>& strs, int m, int n) {
        int len=strs.size();//优化
        vector<vector<int>> dp(m+1,vector<int>(n+1,0));
        for(int i=1;i<=len;i++){
            for(int j=m;j>=0;j--){
                for(int k=n;k>=0;k--){
                    int size_0=0; int size_1=0;
                    for(char &ch:strs[i-1]){
                        if(ch=='0') size_0+=1;
                        else if(ch=='1') size_1+=1;
                    }
                    if(j>=size_0&&k>=size_1){
                        dp[j][k]=max(dp[j][k],dp[j-size_0][k-size_1]+1);//优化前,从小到大的话,一层状态转移从下标小的开始,如果要优化,使用滚动数组的话吗,必须从下标大的开始(二维数组的右下角),否则状态可能从同次转移。
                    }
                }
            }
        }
        return dp[m][n];
    }
};


// class Solution {
// public:
//     int findMaxForm(vector<string>& strs, int m, int n) {
//         int len=strs.size();
//         vector<vector<vector<int>>> dp(len+1,vector<vector<int>>(m+1,vector<int>(n+1,0)));  
//         for(int i=1;i<=len;i++){
//             for(int j=0;j<=m;j++){
//                 for(int k=0;k<=n;k++){
//                     dp[i][j][k]=dp[i-1][j][k];
//                     int size_0=0; int size_1=0;
//                     for(char &ch:strs[i-1]){
//                         if(ch=='0') size_0+=1;
//                         else if(ch=='1') size_1+=1;
//                     }
//                     if(j>=size_0&&k>=size_1){
//                         dp[i][j][k]=max(dp[i-1][j][k],dp[i-1][j-size_0][k-size_1]+1);
//                     }
//                 }
//             }
//         }
//         return dp[len][m][n];
        
//     }
// };

879. 盈利计划 - 力扣(LeetCode)

class Solution {
public:
    int profitableSchemes(int n, int minProfit, vector<int>& group, vector<int>& profit) {
        int m=group.size();
        const int MOD=1e9+7;
        vector<vector<vector<int>>> dp(m+1,vector<vector<int>>(n+1,vector<int>(minProfit+1,0)));
        for(int j=0;j<=n;j++){
            dp[0][j][0]=1;
        }
        for(int i=1;i<=m;i++){
            for(int j=0;j<=n;j++){
                for(int k=0;k<=minProfit;k++){
                    dp[i][j][k]=dp[i-1][j][k];
                    if(j>=group[i-1]){//&&k>=profit[i-1],利润不用处理,因为profit[i-1]>k,表示利润高,这种情况可以取
                        dp[i][j][k]+=dp[i-1][j-group[i-1]][max(0,k-profit[i-1])];
                        dp[i][j][k]=dp[i][j][k]%MOD;
                    }
                }
            }
        }
        return dp[m][n][minProfit];
        
    }
};

377. 组合总和 Ⅳ - 力扣(LeetCode)

与找521 零钱兑换的方式的区别,这个是排列,顺序不同,也统计次数。

class Solution {
public:
    int combinationSum4(vector<int>& nums, int target) {
        int n=nums.size();
        vector<double> dp(target+1,0);
        //求target==0的排列。
        dp[0]=1;
        for(int i=1;i<=target;i++){
            for(int &x:nums){
                if(x<=i)
                dp[i]+=dp[i-x];
            }
        }
        return dp[target];
    }
};

96. 不同的二叉搜索树 - 力扣(LeetCode)

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1810869.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

全球微型光谱仪市场规模逐渐扩大 智能手机为最大应用领域

全球微型光谱仪市场规模逐渐扩大 智能手机为最大应用领域 光谱仪又称为分光仪&#xff0c;是用来测量光谱成分的一种仪器&#xff0c;可以检测特定波长的电磁辐射形成的光谱&#xff0c;从而获取有关物质的结构和动力学等信息。微型光谱仪是光谱仪的细分产品之一&#xff0c;具…

原腾讯云副总裁张纾翔加入矩阵起源,共筑人工智能新篇章

近日&#xff0c;原腾讯云副总裁张纾翔先生正式加入矩阵起源&#xff0c;担任合伙人兼高级副总裁&#xff0c;全面负责矩阵起源商业化工作。 矩阵起源成立于2021年。公司创始团队来自腾讯云、Snowflake等国内外一流的互联网企业、软件公司、数字化企业和开源社区&#xff0c;核…

使用 Transformer 完成 IMDB 情感分类任务

前言 本文使用简单的 Transformer Block 实现对影评文本数据 IMDB 的情感分类任务。 数据 这里定义了两个关键的超参数&#xff1a; vocab_size&#xff1a;表示词汇表的大小&#xff0c;即允许在文本数据中使用的不同的单词数量。maxlen&#xff1a;表示文本序列的最大长度&…

AI大模型-机器学习中的集成学习

机器学习中的集成学习 集成学习概述及主要研究领域 1.1 集成学习概述&#x1f4a5; “众人拾柴火焰高”、“三个臭皮匠顶个诸葛亮”等词语都在表明着群体智慧的力量&#xff0c;所谓的“群体智慧”指的就是一群对某个主题具有平均知识的人集中在一起可以对某一些问题提供出更…

觅瑞集团两年亏损9亿:现金流承压营销成本近亿,应收账款周期过长

《港湾商业观察》黄懿 4月30日&#xff0c;Mirxes Holding Company Limited&#xff08;下称“觅瑞集团”&#xff09;递表港交所&#xff0c;拟在香港主板挂牌上市&#xff0c;中金和建银国际为联席保荐人&#xff0c;这是继2023年7月25日递表失效后的再一次申请。觅瑞集团国…

记录vue一个echarts页面 柱状图加平均分横线 双柱状图 横向双柱状图

<template><div class"app-container"><el-form :model"queryParams" ref"queryForm" size"small" v-show"showSearch" label-width"85px"><el-form-item label"园所名称" prop&q…

【Vue】智慧商城

步骤一般都是&#xff1a; 静态结构 > 封装接口 > 路由获取参数 > 获取数据 动态渲染 先封装接口再路由获取参数的原因是因为&#xff0c;只有先封装好了接口&#xff0c;才能知道我们需要哪些参数 接口文档&#xff1a;https://apifox.com/apidoc/shared-12ab6b18-a…

LabVIEW结构体内部缺陷振动检测

结构体内部缺陷会改变其振动特性&#xff0c;通过振动分析可以检测并定位这些缺陷。本文详细分析内部缺陷对振动的影响&#xff0c;从频谱分析、时域分析和模态分析等多角度探讨基于LabVIEW的检测方法&#xff0c;提供实施步骤和注意事项&#xff0c;帮助工程师有效利用LabVIEW…

安全生产信息化平台:高效构建安全台账管理体系

随着科技的飞速发展&#xff0c;信息化已成为推动企业安全生产管理的重要手段。传统的安全台账管理方式&#xff0c;涉及记录、整理、汇编等多个繁琐环节&#xff0c;不仅耗时费力&#xff0c;而且在查找和检索时也不便。安全生产信息化平台的出现&#xff0c;为企业提供了全新…

【Linux】线程(附源码)

目录 1.线程概述 2.创建线程 3.线程退出 4.线程回收 5.线程分离 1.线程概述 线程是轻量级的进程&#xff08;LWP&#xff1a;light weight process&#xff09;&#xff0c;在Linux环境下线程的本质仍是进程。在计算机上运行的程序是一组指令及指令参数的组合&#xff0c;…

[图解]企业应用架构模式2024新译本讲解12-领域模型5

1 00:00:00,560 --> 00:00:04,690 刚才是往那个表里面添加数据了 2 00:00:04,700 --> 00:00:07,960 相当于&#xff0c;或者往这个合同里面添加数据了 3 00:00:08,430 --> 00:00:09,530 现在要查询怎么办 4 00:00:09,900 --> 00:00:10,930 跟前面一样 5 00:00:…

C# WPF入门学习主线篇(八)—— ListBox常见属性和事件

C# WPF入门学习主线篇&#xff08;八&#xff09;—— ListBox常见属性和事件 欢迎来到C# WPF入门学习系列的第八篇。在前面的文章中&#xff0c;我们已经探讨了WPF中的Button、TextBox和Label控件的使用。今天&#xff0c;我们将深入了解WPF中的另一个常用控件——ListBox。本…

java web如何调用py脚本文件

Controller public class IndexController {RequestMapping("/pythonTest")ResponseBodypublic String pythonTest(){// 假设你的Python脚本名为script.pyString pythonScriptPath "D:\\project\\c1\\hello.py";ProcessBuilder processBuilder new Proce…

【解读】小提琴图

ref&#xff1a;解读文献中的箱线图&#xff08;Box-plot&#xff09;和小提琴图&#xff08;Violin-plot)&#xff09;_小提琴图和箱线图的区别-CSDN博客小提琴图展示了每个变量的数据分布情况&#xff0c;通过图中的“小提琴”形状可以看出数据的密度和分布情况。 在图中&…

在Visual Studio Code中使用pytest进行AWS Lambda函数测试的最佳实践

背景/引言 在现代软件开发中&#xff0c;自动化测试已经成为保证代码质量的重要一环。对于AWS Lambda函数开发者来说&#xff0c;使用pytest进行单元测试和集成测试是一个高效且可靠的方法。本文将介绍在Visual Studio Code中使用pytest测试AWS Lambda函数的最佳实践&#xff…

攸信动态丨攸信技术接受厦门电视台《厦视直播室》栏目组采访

近日&#xff0c;厦门攸信信息技术有限公司&#xff08;简称“攸信技术&#xff08;UMS&#xff09;”&#xff09;荣幸地接受厦门电视台《厦视直播室》栏目组的采访。 智能制造作为当今技术创新的前沿阵地&#xff0c;正日益成为推动工业发展的核心力量。攸信技术&#xff0c;…

门禁系统一套多少钱,门禁系统设备的价格

门禁系统一套多少钱&#xff0c;门禁系统设备的价格 现今门禁系统有诸多品牌&#xff0c;不同品牌的价格亦有所差别&#xff1b;知名的大品牌价格往往更贵&#xff0c;而一些小众品牌又不太了解&#xff0c;价格虽便宜些&#xff0c;却担心质量不佳&#xff0c;售后也不好处理&…

适用于 macOS 的最佳免费数据恢复软件

升级到 macOS 后&#xff0c;它可以帮助您从 HDD、SSD、存储卡、USB 闪存驱动器、数码相机或其他存储介质设备中完全恢复已删除、格式化或无法访问的数据。 当 macOS Monterey 用户寻找数据恢复解决方案时&#xff0c;免费数据恢复软件始终是一个不错的选择。实际上&#xff0…

FuTalk设计周刊-Vol.060

#AI漫谈 热点捕手 1.浙大、蚂蚁集团推出MaPa&#xff1a;文本生成超真实3D模型 与传统纹理方法不同的是&#xff0c;MaPa通过文本能直接生成高分辨率、物理光照、超真实材质的3D模型&#xff0c;可以极大提升游戏、VR、AR、影视等行业的开发效率。 链接https://mp.weixin.qq…

Elasticsearch 为时间序列数据带来存储优势

作者&#xff1a;来自 Elastic Martijn Van Groningen, Kostas Krikellas 背景 Elasticsearch 最近投资了对存储和查询时间序列数据的更好支持。存储效率一直是关注的主要领域&#xff0c;许多项目取得了巨大的成功&#xff0c;与将数据保存在标准索引中相比&#xff0c;可以节…