第34次CCF-CSP认证第4题,货物调度

题目链接TUOJ

这道题是背包DP+贪心。这很明显是分组背包,一个仓库是一组,因为代价是和仓库和数量有关,与具体的货物无关(这也是贪心的基础)。

1.我们遍历每一组,对每一组的物品价值从大到小排序。这是很明显的,再这一组中选一定数量的物品代价就是一定的,我们肯定会选价值较高的才能得到最优解。

2.40000是通过数据范围算出来的最大代价,接下来就是跑分组背包的代码。

cpp 复制代码
#include<bits/stdc++.h>
#define ll long long 
using namespace std;
int n,m,v,b[1005],c[1005],dp[40005];
vector<int>arr[1005];
int main()
{
cin>>n>>m>>v;
for(int i=0;i<n;i++){
	cin>>b[i]>>c[i];
}
int a,t;
for(int i=0;i<m;i++){
	cin>>a>>t;
	arr[t].push_back(a);
}
for(int i=0;i<=n;i++){
	sort(arr[i].begin(),arr[i].end(),greater<int>());
	for(int j=40000;j>=0;j--){
		int sum=0;
		for(int k=0;k<arr[i].size();k++){
			if(b[i]+c[i]*(k+1)<=j){
				sum+=arr[i][k];
				dp[j]=max(dp[j],dp[j-(b[i]+c[i]*(k+1))]+sum);
			}
			else break;
		}
	}
}
for(int i=1;i<=40000;i++){
	if(dp[i]-i>=v){
		cout<<i;
		return 0;
	}
}
	return 0;
}
相关推荐
刀法如飞2 分钟前
JavaScript 数组去重的 20 种实现方式,学会用不同思路解决问题
前端·javascript·算法
洛水水10 分钟前
【力扣100题】46.单词拆分
算法·leetcode·职场和发展
MicroTech202542 分钟前
量子安全赋能协同智能,微算法科技(NASDAQ :MLGO)研发PQS-BFL后量子区块链联邦学习框架
科技·算法·安全
计算机安禾1 小时前
【c++面向对象编程】第21篇:运算符重载基础:语法、规则与不可重载的运算符
java·前端·c++
开发者联盟league1 小时前
在cursor中配置c/c++开发环境
c语言·开发语言·c++
平行侠1 小时前
A19 工业设备故障决策树智能诊断系统
算法·决策树·机器学习
澈2071 小时前
平衡二叉树:AVL与红黑树终极对比
数据结构·c++·红黑树
铮铭1 小时前
【论文阅读】世界模型发展脉络整理---Understanding World or Predicting Future? A Comprehensive Survey of World Models
论文阅读·人工智能·算法·机器人
ComputerInBook1 小时前
C++ 中的 lambda 表达式
开发语言·c++·lambda表达式·匿名函数
灵智实验室2 小时前
PX4状态估计技术EKF2详解(四):EKF2 Output Predictor——从延迟估计到实时输出
算法·无人机·px 4