UVALive 5066 Fire Drill --BFS+DP
题意:有一个三维的地图,有n个人被困住,现在消防队员只能从1楼的一个入口进入,营救被困者,每一个被困者有一个价值,当消防队员找到一个被困者之后,他可以营救或者见死不救,如果救的话,他必须马上将其背到入口处,不得停下,不得同时救多个人,而且回去的时间一步要做两步走,即时间增加一倍。求在给定时间S内,能救到的人的最大价值总和。
解法:bfs一遍记录每个点离起点的最短距离,那么救这个人的花费就是3*dis,然后已经知道救这个人的价值,那么最后求一个01背包即可。
要注意一个人都救不到的地方,我开始将dis都初始化为1000000007,这样的话如果走不到的话,花费就变成3*dis爆int了。悲剧。
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <algorithm>
#include <queue>
#define Mod 10000007
using namespace std;
#define N 50107 char mp[][][];
int dis[][][];
int dp[];
int T[],P[],L,H,W;
int dx[] = {,,,, , -};
int dy[] = {,,-,, , ,};
int dz[] = {,,,-, , ,};
struct node {
int l,h,w,sec;
node(int _x,int _y,int _z,int _sec):l(_x),h(_y),w(_z),sec(_sec){}
node(){}
}vol[],S; bool OK(int x,int y,int z) {
if(x >= && x < L && y >= && y < H && z >= && z < W)
return true;
return false;
} void bfs(node S) {
queue<node> q;
while(!q.empty()) q.pop();
int i,j,k;
for(i=;i<L;i++)
for(j=;j<H;j++)
for(k=;k<W;k++)
dis[i][j][k] = Mod;
int x = S.l, y = S.h, z = S.w;
dis[x][y][z] = ;
q.push(S);
while(!q.empty()) {
node now = q.front();
q.pop();
int l = now.l, h = now.h, w = now.w, sec = now.sec;
if(mp[l][h][w] == 'U') {
for(k=;k<;k++) {
int nx = l + dx[k];
int ny = h + dy[k];
int nz = w + dz[k];
if(!OK(nx,ny,nz)) continue;
if(mp[nx][ny][nz] != 'X') {
if(sec+ < dis[nx][ny][nz]) {
dis[nx][ny][nz] = sec+;
node tmp = node(nx,ny,nz,sec+);
q.push(tmp);
}
}
}
}
else if(mp[l][h][w] == 'D') {
for(k=;k<;k++) {
if(k == ) continue;
int nx = l + dx[k];
int ny = h + dy[k];
int nz = w + dz[k];
if(!OK(nx,ny,nz)) continue;
if(mp[nx][ny][nz] != 'X') {
if(sec+ < dis[nx][ny][nz]) {
dis[nx][ny][nz] = sec+;
node tmp = node(nx,ny,nz,sec+);
q.push(tmp);
}
}
}
}
else {
for(k=;k<;k++) {
int nx = l + dx[k];
int ny = h + dy[k];
int nz = w + dz[k];
if(!OK(nx,ny,nz)) continue;
if(mp[nx][ny][nz] != 'X') {
if(sec+ < dis[nx][ny][nz]) {
dis[nx][ny][nz] = sec+;
node tmp = node(nx,ny,nz,sec+);
q.push(tmp);
}
}
}
}
}
} int main()
{
int t,n,STime,i,j,k;
scanf("%d",&t);
while(t--)
{
scanf("%d%d%d%d%d",&L,&H,&W,&n,&STime);
for(i=;i<L;i++) {
for(j=;j<H;j++) {
scanf("%s",mp[i][j]);
for(k=;k<W;k++)
if(mp[i][j][k] == 'S')
S = node(i,j,k,);
}
}
for(i=;i<=n;i++)
{
scanf("%d%d%d%d",&vol[i].l,&vol[i].h,&vol[i].w,&P[i]);
vol[i].l--,vol[i].h--,vol[i].w--;
}
bfs(S);
for(i=;i<=n;i++)
T[i] = *dis[vol[i].l][vol[i].h][vol[i].w];
memset(dp,,sizeof(dp));
for(i=;i<=n;i++) {
for(j=STime;j>=;j--) {
if(j >= T[i])
dp[j] = max(dp[j],dp[j-T[i]]+P[i]);
}
}
int Maxi = ;
for(i=;i<=STime;i++)
Maxi = max(Maxi,dp[i]);
printf("%d\n",Maxi);
}
return ;
}
UVALive 5066 Fire Drill --BFS+DP的更多相关文章
- UVALive 5066 Fire Drill BFS+背包
H - Fire Drill Time Limit:3000MS Memory Limit:0KB 64bit IO Format:%lld & %llu Submit Sta ...
- ACM/ICPC 之 最短路-Floyd+SPFA(BFS)+DP(ZOJ1232)
这是一道非常好的题目,融合了很多知识点. ZOJ1232-Adventrue of Super Mario 这一题折磨我挺长时间的,不过最后做出来非常开心啊,哇咔咔咔 题意就不累述了,注释有写,难点在 ...
- ZOJ 3596Digit Number(BFS+DP)
一道比较不错的BFS+DP题目 题意很简单,就是问一个刚好包含m(m<=10)个不同数字的n的最小倍数. 很明显如果直接枚举每一位是什么这样的话显然复杂度是没有上限的,所以需要找到一个状态表示方 ...
- UVA 11624 - Fire! 图BFS
看题传送门 昨天晚上UVA上不去今天晚上才上得去,这是在维护么? 然后去看了JAVA,感觉还不错昂~ 晚上上去UVA后经常连接失败作死啊. 第一次做图的题~ 基本是照着抄的T T 不过搞懂了图的BFS ...
- 【2019.8.14 慈溪模拟赛 T1】我不是!我没有!别瞎说啊!(notme)(BFS+DP)
\(IDA^*\) 说实话,这道题我一开始没想出正解,于是写了一个\(IDA^*\)... 但神奇的是,这个\(IDA^*\)居然连字符串长度分别为\(2500,4000\)的数据都跑得飞快,不过数据 ...
- UVALive 4025 Color Squares(BFS)
题目链接:UVALive 4025 Color Squares 按题意要求放带有颜色的块,求达到w分的最少步数. //yy:哇,看别人存下整个棋盘的状态来做,我什么都不想说了,不知道下午自己写了些什么 ...
- AOJ 0121: Seven Puzzle (BFS DP STL 逆向推理)(转载)
转载自: http://m.blog.csdn.net/blog/Enjoying_Science/42008801 题目链接:http://acm.hust.edu.cn/vjudge/probl ...
- HDU3247 Resource Archiver(AC自动机+BFS+DP)
题目,求最短的包含所有n个DNA片段且不包含任何一个病毒片段的序列. 容易用所有DNA片段和病毒片段建一个AC自动机,构造fail时处理一下各个结点后缀是DNA或者病毒的情况,然后dp[S][u]表示 ...
- UVa 11624 Fire!(BFS)
Fire! Time Limit: 5000MS Memory Limit: 262144KB 64bit IO Format: %lld & %llu Description Joe ...
随机推荐
- easyUI 后台经典框架DEMO下载
采用easyui 1.2.6 + jquery 1.7.2 设计 有不明白的朋友加群或加我QQ (709047174) Jquery-EasyUi-demo点击我下载
- 浅析css布局模型2
上节对整个布局模型进行了概述,这节先谈一下布局模型的几个属性. z-index属性 该属性是检索或设置对象的层叠顺序,默认值为auto,遵循其父对象的定位. 并级的对象,该属性的值越大,则被层叠在最上 ...
- MSCRM 2013/2015 Ribbon Editor
由于新版本2015的解决方案与之前有变化,因此许多老的Tools已经不能使用,推荐给大家新的Ribbon Editor Tool. 下载地址: http://www.develop1.net/publ ...
- Sharepoint学习笔记—习题系列--70-576习题解析 -(Q13-Q15)
Question 13 You are designing a SharePoint 2010 site. You need to design the site to meet all the fo ...
- android编译系统的makefile文件Android.mk写法
Android.mk文件首先需要指定LOCAL_PATH变量,用于查找源文件.由于一般情况下Android.mk和需要编译的源文件在同一目录下,宏函数“my-dir”右编译系统提供的,用于返回当前路径 ...
- Android 图片的缩放与旋转
本文实现Android中的图片的缩放效果 首先设计布局: <LinearLayout xmlns:android="http://schemas.android.com/apk/res ...
- iOS底层基础知识-文件目录结构
一:iOS沙盒知识 出于安全考虑,iOS系统把每个应用以及数据都放到一个沙盒(sandbox)里面,应用只能访问自己沙盒目录里面的文件.网络资源等(也有例外,比如系统通讯录.照相机.照片等能在用户授权 ...
- 【代码笔记】iOS-两个时间字符串的比较
一,效果图. 二,代码. - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the ...
- iOS开发之JSON格式数据的生成与解析
本文将从四个方面对IOS开发中JSON格式数据的生成与解析进行讲解: 一.JSON是什么? 二.我们为什么要用JSON格式的数据? 三.如何生成JSON格式的数据? 四.如何解析JSON格式的数据? ...
- Android按键事件处理流程 -- KeyEvent
刚接触Android开发的时候,对touch.key事件的处理总是一知半解,一会是Activity里的方法,一会是各种View 中的,自己始终不清楚到底哪个在先哪个在后,总之对整个处理流程没能很好的把 ...