代码随想录Day46 | 139.单词拆分 | 4. 多重背包问题 I

139. 单词拆分

cpp 复制代码
class Solution {
public:
    bool wordBreak(string s, vector<string>& wordDict) {
        unordered_set<string> wordset(wordDict.begin(),wordDict.end());
            vector<bool> f(s.size()+1,false);
            f[0]=true;
            for(int i=1;i<=s.size();i++){
                for(int j=0;j<i;j++){
                    string word = s.substr(j,i-j);
                    if(wordset.count(word)&&f[j]) //当f[j]为true,且f[i-j]可以由字典得到,则f[i] = true
                    f[i]=true;
                }
            }
            return f[s.size()];
        }
};

4. 多重背包问题 I(acwing)

有 N 种物品和一个容量是 V的背包。

第 i种物品最多有 si 件,每件体积是 vi,价值是 wi。

求解将哪些物品装入背包,可使物品体积总和不超过背包容量,且价值总和最大。

输出最大价值。

输入格式

第一行两个整数,N,V,用空格隔开,分别表示物品种数和背包容积。

接下来有 N 行,每行三个整数 vi,wi,si,用空格隔开,分别表示第 i 种物品的体积、价值和数量。

输出格式

输出一个整数,表示最大价值。

数据范围

0<N,V≤100

0<vi,wi,si≤100

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 110;
int n,v;
int v1[N];
int w[N];
int s[N];
int f[N];

int main()
{
    cin >> n>>v;
    for (int i = 1; i <= n; i ++ ){
        cin>>v1[i];
        cin>>w[i];
        cin>>s[i];
    }
    for(int i=1;i<=n;i++){
        for(int j=v;j>=v1[i];j--){
                for(int k=0;k<=s[i];k++){
                    if(j>=k*v1[i])
                    f[j]=max(f[j],f[j-k*v1[i]]+k*w[i]);
                }
            }
        }
    cout<<f[v];
}
相关推荐
田梓燊10 分钟前
leetcode 234
算法·leetcode·职场和发展
Aaron158812 分钟前
RFSOC+VU13P中在线部分可重构技术的应用分析
人工智能·算法·matlab·fpga开发·重构·信息与通信·信号处理
yashuk18 分钟前
C语言入门教程:程序结构与算法举例
c语言·算法·教程·程序设计·开发过程
zsc_11822 分钟前
pvz3解码小游戏求解算法 (二)
算法
hanbr30 分钟前
每日一题day1(Leetcode 76最小覆盖子串)
算法·leetcode
AI科技星31 分钟前
张祥前统一场论中两个电荷定义的统一性解析
开发语言·线性代数·算法·数学建模·平面
代码地平线32 分钟前
C语言实现堆与堆排序详解:从零手写到TopK算法及时间复杂度证明
c语言·开发语言·算法
小江的记录本32 分钟前
【大语言模型】大语言模型——核心概念(预训练、SFT监督微调、RLHF/RLAIF对齐、Token、Embedding、上下文窗口)
java·人工智能·后端·python·算法·语言模型·自然语言处理
炘爚34 分钟前
LeetCode(两两交换链表中的节点)
算法·leetcode·链表
wsoz34 分钟前
Leetcode矩阵-day7
c++·算法·leetcode·矩阵