题意:有一个三维的地图,有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的更多相关文章

  1. UVALive 5066 Fire Drill BFS+背包

    H - Fire Drill Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Submit Sta ...

  2. ACM/ICPC 之 最短路-Floyd+SPFA(BFS)+DP(ZOJ1232)

    这是一道非常好的题目,融合了很多知识点. ZOJ1232-Adventrue of Super Mario 这一题折磨我挺长时间的,不过最后做出来非常开心啊,哇咔咔咔 题意就不累述了,注释有写,难点在 ...

  3. ZOJ 3596Digit Number(BFS+DP)

    一道比较不错的BFS+DP题目 题意很简单,就是问一个刚好包含m(m<=10)个不同数字的n的最小倍数. 很明显如果直接枚举每一位是什么这样的话显然复杂度是没有上限的,所以需要找到一个状态表示方 ...

  4. UVA 11624 - Fire! 图BFS

    看题传送门 昨天晚上UVA上不去今天晚上才上得去,这是在维护么? 然后去看了JAVA,感觉还不错昂~ 晚上上去UVA后经常连接失败作死啊. 第一次做图的题~ 基本是照着抄的T T 不过搞懂了图的BFS ...

  5. 【2019.8.14 慈溪模拟赛 T1】我不是!我没有!别瞎说啊!(notme)(BFS+DP)

    \(IDA^*\) 说实话,这道题我一开始没想出正解,于是写了一个\(IDA^*\)... 但神奇的是,这个\(IDA^*\)居然连字符串长度分别为\(2500,4000\)的数据都跑得飞快,不过数据 ...

  6. UVALive 4025 Color Squares(BFS)

    题目链接:UVALive 4025 Color Squares 按题意要求放带有颜色的块,求达到w分的最少步数. //yy:哇,看别人存下整个棋盘的状态来做,我什么都不想说了,不知道下午自己写了些什么 ...

  7. AOJ 0121: Seven Puzzle (BFS DP STL 逆向推理)(转载)

    转载自:  http://m.blog.csdn.net/blog/Enjoying_Science/42008801 题目链接:http://acm.hust.edu.cn/vjudge/probl ...

  8. HDU3247 Resource Archiver(AC自动机+BFS+DP)

    题目,求最短的包含所有n个DNA片段且不包含任何一个病毒片段的序列. 容易用所有DNA片段和病毒片段建一个AC自动机,构造fail时处理一下各个结点后缀是DNA或者病毒的情况,然后dp[S][u]表示 ...

  9. UVa 11624 Fire!(BFS)

    Fire! Time Limit: 5000MS   Memory Limit: 262144KB   64bit IO Format: %lld & %llu Description Joe ...

随机推荐

  1. 推荐15款最佳的响应式 Web 设计测试工具

    响应式网页设计是根据设备的屏幕尺寸,平台和方向来开发的网页,是一种对最终用户的行为和环境作出反应的方法.响应式设计使用灵活的网格和布局,图像和智能使用 CSS 媒体查询的组合.当从它们在不同设备使用的 ...

  2. jQuery原型方法each使用和源码分析

    jQuery.each方法是jQuery的核心工具方法之一,通用例遍方法,可用于例遍对象和数组.不同于例遍 jQuery 对象的 $().each() 方法,此方法可用于例遍任何对象.通常需要两个参数 ...

  3. Refusing to install webpack as a dependency of itself

    用npm安装webpack的时候报了这个错: Refusing to install webpack as a dependency of itself 翻译过来大概是:'拒绝安装webpack其本身 ...

  4. C/C++构建系统 CMake

    Cmake实践 Cmake Practice –Cjacker cmake是kitware公司以及一些开源开发者在开发几个工具套件(VTK)的过程中衍 生品,最终形成体系,成为一个独立的开放源代码项目 ...

  5. Android TextView 高亮字体并添加点击事件

    运行效果 package com.zutil.lib; import android.graphics.Typeface; import android.os.Bundle; import andro ...

  6. Android C代码回调java方法

    本文将讲述下列三种C代码回调java方法 1.c代码回调java空方法 2.c代码回调java int类型参数方法 3.c代码回调javaString类型参数方法 方法都差不多,先看c代码回调java ...

  7. Java 往年试卷参考答案!!!

    仅供参考: 第一题: E C E A D D C A C A C A B A B C C D B C 第二题: True True False 11 12 13 14 No such file fou ...

  8. Token原理以及应用

    近期由于项目需要开发供第三方使用的api,在整个架构设计的一个环节中,对api访问需要进行认证,在这里我选择了token认证. 一:token的优势(此部分引自http://www.sumahe.cn ...

  9. 如何通过js跨域调用ASP.NET Web API (请问如何实现在javascript中通过http get的方式跨域调用ASP.NET Web API?)

    客户端js无需任何专门设置,使用通常的ajax调用即可: $.ajax({ url: '跨域URL', type: 'get', dataType: 'json', success: function ...

  10. 用css3绘制你需要的几何图形

    1.圆形 示例: 思路:给任何正方形元素设置一个足够大的 border-radius ,就可以把它变成一个圆形.代码如下: html: <div class="size example ...