Mr. Panda and Crystal HDU - 6007 最短路+完全背包
题目:题目链接
思路:不难看出,合成每个宝石需要消耗一定的魔力值,每个宝石有一定的收益,所以只要我们知道每个宝石合成的最小花费,该题就可以转化为一个背包容量为初始魔力值的完全背包问题,每个宝石的最小花费可以用dijkstra跑一遍最短路算出,路径长度用合成花费表示。
AC代码:
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <vector>
#include <queue> using namespace std; const int maxn = + ; int vol, n, m, INF; struct node {
int c, w;
vector<int> v;
vector<vector<pair<int, int> > > vec;
friend bool operator < (node a, node b) {
return a.w > b.w;
}
}gem[maxn]; priority_queue<pair<int, int>, vector<pair<int, int>>, greater<pair<int, int>> > q; bool vis[maxn]; void init() {
for(int i = ; i <= n; ++i) {
for(int j = ; j < gem[i].vec.size(); ++j)
gem[i].vec[j].clear();
gem[i].vec.clear();
gem[i].v.clear();
}
while(!q.empty())
q.pop();
memset(vis, false, sizeof(vis));
} bool get_sum(int id) {
int sum, _min = INF;
for(int i = ; i < gem[id].vec.size(); ++i) {
sum = ;
for(int j = ; j < gem[id].vec[i].size(); ++j) {
sum += gem[gem[id].vec[i][j].first].c * gem[id].vec[i][j].second;
if(sum > INF)
sum = INF;
}
_min = min(_min, sum);
}
if(_min < gem[id].c) {
gem[id].c = _min;
return true;
}
return false;
} void dijkstra() {
while(!q.empty()) {
pair<int, int> P = q.top();
q.pop();
if(vis[P.second])
continue;
vis[P.second] = true;
for(int i = ; i < gem[P.second].v.size(); ++i) {
if(!vis[gem[P.second].v[i]] && get_sum(gem[P.second].v[i])) {
q.push(make_pair(gem[gem[P.second].v[i]].c, gem[P.second].v[i]));
}
}
}
} int dp[maxn]; int main()
{
ios::sync_with_stdio();
cin.tie(); int T, t = ;
cin >> T;
while(T--) {
cin >> vol >> n >> m;
INF = vol + ;
init();
int flag;
for(int i = ; i <= n; ++i) {
cin >> flag;
if(flag)
cin >> gem[i].c >> gem[i].w;
else {
cin >> gem[i].w;
gem[i].c = INF;
}
}
int id, num, c, nu;
vector<pair<int, int> > ope;
for(int i = ; i < m; ++i) {
cin >> id >> num;
ope.clear();
for(int j = ; j < num; ++j) {
cin >> c >> nu;
ope.push_back(make_pair(c, nu));
gem[c].v.push_back(id);
}
gem[id].vec.push_back(ope);
} for(int i = ; i <= n; ++i)
if(gem[i].c < INF)
q.push(make_pair(gem[i].c, i)); dijkstra(); memset(dp, , sizeof(dp));
for(int i = ; i <= n; ++i)
for(int v = ; v <= vol; ++v)
if(v >= gem[i].c)
dp[v] = max(dp[v], dp[v - gem[i].c] + gem[i].w); cout << "Case #" << ++t << ": " << dp[vol] << endl;
}
return ;
}
Mr. Panda and Crystal HDU - 6007 最短路+完全背包的更多相关文章
- hdu6007 Mr. Panda and Crystal 最短路+完全背包
/** 题目:hdu6007 Mr. Panda and Crystal 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6007 题意:魔法师有m能量,有n ...
- HDU 6007 Mr. Panda and Crystal (背包+spfa)
题意:你生活在一个魔法大陆上,你有n 魔力, 这个大陆上有m 种魔法水晶,还有n 种合成水晶的方式,每种水晶价格告诉你,并且告诉你哪些水晶你能直接造出来,哪些你必须合成才能造出来,问你n魔力最多能卖多 ...
- Mr. Panda and Crystal(最短路+完全背包)
http://codeforces.com/gym/101206/attachments 题意: T组输入,每组给出m,n,k,m为能量总数,n为水晶种类数,k为合成方案数.有的水晶可以用能量制造,有 ...
- HDU 3339 最短路+01背包
In Action Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- ACM: HDU 2544 最短路-Dijkstra算法
HDU 2544最短路 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Descrip ...
- UESTC 30 &&HDU 2544最短路【Floyd求解裸题】
最短路 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- hdu 5521 最短路
Meeting Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- HDU 3339 In Action【最短路+01背包】
题目链接:[http://acm.hdu.edu.cn/showproblem.php?pid=3339] In Action Time Limit: 2000/1000 MS (Java/Other ...
- 2018 China Collegiate Programming Contest Final (CCPC-Final 2018)-K - Mr. Panda and Kakin-中国剩余定理+同余定理
2018 China Collegiate Programming Contest Final (CCPC-Final 2018)-K - Mr. Panda and Kakin-中国剩余定理+同余定 ...
随机推荐
- CoreCLR源码2
CoreCLR源码 前一篇我们看到了CoreCLR中对Object的定义,这一篇我们将会看CoreCLR中对new的定义和处理new对于.Net程序员们来说同样是耳熟能详的关键词,我们每天都会用到ne ...
- 070 Climbing Stairs
你正在爬楼梯.需要 n 步你才能到达顶部.每次你可以爬 1 或 2 个台阶.你有多少种不同的方式可以爬到楼顶呢?注意:给定 n 将是一个正整数.示例 1:输入: 2输出: 2说明: 有两种方法可以爬到 ...
- JS filter使用
filter 用于筛选数组中符合条件的所以元素,filter只能接受函数 注意:filter只返回筛选结果,不会对原来数组改变 实现方法: <html lang="en"&g ...
- Webpack 入门学习
1.什么是Webpack? Webpack可以看做是模块打包机:它做的事情是,分析你的项目结构,找到JavaScript模块以及其它的一些浏览器不能直接运行的拓展语言(Scss,TypeScript等 ...
- Docker 给运行中的容器添加映射端口
方法1 1.获得容器IP 将container_name 换成实际环境中的容器名 docker inspect `container_name` | grep IPAddress 2. iptable ...
- SVN合并步骤
1.trunk->branch/tag 分支路径在分支文件夹中,选择右键检出 2.合并分支到主干分支新增 1.txt 文件 需要合并到主干 在trunck->鼠标右键合并->合并到不 ...
- SQL SERVER之填充因子
建SQL SERVER索引的时候有一个选项,即Fillfactor(填充因子). 这个可能很少人会去注意它,但它也是比较重要的.大家可能也都知道有这个东西,但是如何去使用它,可能会比较迷糊.另外,即使 ...
- setup命令
setup——配置网络(centos) 命令所在路径:usr/bin/setup 示例1: # setup
- Unity3D中使用Projector生成阴影
在Unity3D中使用Projector实现动态阴影 无意中看见一篇博客叙述使用Projector实现动态阴影可以在移动平台拥有非常好的性能,遂按照其想法实现了一遍,发现其中竟有许多细节,写下这篇博客 ...
- Robot Framework(一)入门
1.1简介 Robot Framework是一个基于Python的,可扩展的关键字驱动的测试自动化框架,用于端到端验收测试和验收测试驱动开发(ATDD).它可用于测试分布式异构应用程序,其中验证需要涉 ...