超出背包限制--潜水员

本题和之前的二维背包差不多,但是它可以做到超出体积的限制,本质上我们的状态转移方程其实和之前的差不多,fij=min(fi-1j,fi-1j-v+w),超出的体积应该如何去计算,我们可以利用负数去计算,也就是i-v1<0||j-v2<0但是这样会造成数组越界,我们只需要让他们呢和0比较即可,fmax(0,i-v1)max(0,j-v2)+w。本质上就是只要超过氧气,氮气的含量,不管多少,直接和f00比较,得到的就是当前最小的重量。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int f[1010][1010];
int main()
{
    int n,m;
    cin>>n>>m;
    int q;
    cin>>q;
    memset(f,0x3f,sizeof(f));
    f[0][0]=0;
    for(int i=1;i<=q;i++)
    {
        int v1,v2,w;
        cin>>v1>>v2>>w;
        for(int j=n;j>=0;j--)
        {
            for(int k=m;k>=0;k--)
            {
                f[j][k]=min(f[j][k],f[max(0,j-v1)][max(0,k-v2)]+w);
            }
        }
    }
    // for(int i=1;i<=n;i++)
    // {
    //     for(int j=1;j<=m;j++)
    //     {
    //         cout<<f[i][j]<<" ";
    //     }
    //     cout<<endl;
    // }
    cout<<f[n][m]<<endl;
    return 0;
}
相关推荐
AI人工智能+电脑小能手3 分钟前
【大白话说Java面试题 第97题】【Mysql篇】第27题:说说分库与分表的设计?
java·开发语言·数据库·分布式·mysql·算法
yuan1999711 分钟前
双目视觉测距实现
算法
洒脱的六边形战士加辣12 分钟前
Java排序方法全解析
java·数据结构·算法
代码中介商23 分钟前
LRU缓存算法:双向链表+哈希表实现
算法·链表·缓存
lqqjuly26 分钟前
计算理论—图灵机、复杂性、信息论与机器学习的理论基础
算法
Hiter_John40 分钟前
Golang的循环语句
开发语言·算法·golang
磊 子1 小时前
STL算法库讲解1
开发语言·c++·算法
8Qi81 小时前
LeetCode 474:一和零(Ones and Zeroes)—— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包
stolentime1 小时前
CF2066D2 Club of Young Aircraft Builders (hard version)题解
c++·算法·动态规划·组合数学
一个不知名程序员www1 小时前
算法学习入门---算法题DAY3
c++·算法