J.搬砖【蓝桥杯】/01背包+贪心

搬砖


01背包+贪心

思路:要让重量更小的在更前面,价值更大的在更后面,vi−wj>vj−wi = vi+wi>vj+wj

第 i 个箱子放在第 j 个箱子下面就显然更优。所以进行排序再用01背包即可。

cpp 复制代码
#include<iostream>
#include<algorithm>
#define endl '\n'
using namespace std;
typedef long long ll;
struct node
{
    ll w,v;
}arr[1005];
bool cmp(node &n1,node &n2)
{
    return n1.v+n1.w<n2.v+n2.w;
}
ll dp[1005][20005];
int main()
{
    int n;
    cin>>n;
    for(int i=1;i<=n;i++) cin>>arr[i].w>>arr[i].v;
    sort(arr+1,arr+n+1,cmp);
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=20*n;j++)
        {
            ll y=min(j-arr[i].w,arr[i].v);
            if(y<0)
            {
                dp[i][j]=dp[i-1][j];
                continue;
            }
            dp[i][j]=max(dp[i-1][j],dp[i-1][y]+arr[i].v);
        }
    }
    cout<<dp[n][20*n]<<endl;
    return 0;
}
相关推荐
_OP_CHEN1 天前
【算法基础篇】(二十九)路径类线性 DP 保姆级教程:从矩阵到迷宫,覆盖 4 道经典题 + 优化神技
算法·矩阵·蓝桥杯·动态规划·算法竞赛·acm/icpc·路径类动态规划
_OP_CHEN2 天前
【算法基础篇】(二十八)线性动态规划之基础 DP 超详解:从入门到实战,覆盖 4 道经典例题 + 优化技巧
算法·蓝桥杯·动态规划·运筹学·算法竞赛·acm/icpc·线性动态规划
云泽8082 天前
蓝桥杯算法精讲:前缀和与差分算法的应用与实战
算法·职场和发展·蓝桥杯
Swift社区2 天前
LeetCode 444 - 序列重建
算法·leetcode·蓝桥杯
potato_may3 天前
工程框架搭建(续)
蓝桥杯·嵌入式·硬件·国赛·调度器·裸机开发·stm2
potato_may3 天前
第三章:LED 模块详解
蓝桥杯·cubemx·嵌入式·led·stm332
不能只会打代码3 天前
蓝桥杯---垒骰子(Java实现,代码注释,图文讲解)
算法·蓝桥杯·动态规划·垒骰子
沧澜sincerely3 天前
蓝桥杯11 路径之谜
c++·蓝桥杯·stl·dfs·剪枝
Swift社区4 天前
LeetCode 443. 压缩字符串
leetcode·职场和发展·蓝桥杯
_OP_CHEN4 天前
【算法基础篇】(二十七)从记忆化搜索到动态规划:保姆级入门指南,带你吃透 DP 核心思想!
算法·蓝桥杯·动态规划·记忆化搜索·算法竞赛·acm/icpc