hdu 1044 BFS(压缩图)+DFS
题意:
给你起点,终点,图上有墙有路还有宝物,问你在规定时间内能否能到终点,如果能问最多能捡到多少宝物.
思路:
看完这个题目果断 BFS+三维的mark[][][] 第三维用二进制压缩的思想去解决,结果TLE了,我后来在网上看了看,发现有人用二进制压缩ac了,这更坚定了我的决心啊,不停的优化 超时 优化 超时 就这样我超时了 50多次,我tm恶心了,直接粘了个网上说和我想法一样的代码交上去了,结果 TLE 了, 我 fuck ,超时了早说啊... ,可能是数据加强了.
下面说一下正解 ,观察我们发现,题目中给的宝贝数量并不多,最多才10 ,其实我们可以先 BFS求出所有点的最短路,这些点包括 ,起点,终点,宝物,求完最短路我们其实就把这个图压缩成了最多 10 + 1 + 1 个点,压缩了图之后就是暴力DFS了,12个点压力也有点大,所以要剪枝 , 在深搜的时候如果发现当前的可满足ans 已经等于宝物总和了,那么不用在搜了,直接return 到最外面,或者可以再加上一个就是,当前的所用时间 + 当前到终点的时间
大于题目给的时间限制了,直接return 到上一层;
/*
先BFS把图压缩,在DFS爆搜
*/
#include<stdio.h>
#include<string.h>
#include<queue>
#define N1 60
#define N2 15
using namespace std;
typedef struct
{
int x ,y ,t;
}NODE;
NODE xin ,tou;
int mark_bfs[N1][N1] ,mark_dfs[N2];
int dis[N2][N2] ,money[N2];
int dir[4][2] = {0 ,1 ,0 ,-1 ,1 ,0 ,-1 ,0};
char map[N1][N1];
int xx ,yy ,tt ,mm ,ss ,nn;
bool ok(int x ,int y)
{
if(x >= 0 && x < xx && y >= 0 && y < yy && map[x][y] != '*' && !mark_bfs[x][y])
return 1;
return 0;
}
void BFS(int x ,int y ,int key)// 求那几个点之间的最短路,key当前是起始点.
{
memset(mark_bfs ,0 ,sizeof(mark_bfs));
mark_bfs[x][y] = 1;
xin.x = x ,xin.y = y ,xin.t = 0;
queue<NODE>q;
q.push(xin);
while(!q.empty())
{
tou = q.front();
q.pop();
for(int i = 0 ;i < 4 ;i ++)
{
xin.x = tou.x + dir[i][0];
xin.y = tou.y + dir[i][1];
xin.t = tou.t + 1;
if(ok(xin.x ,xin.y))
{
mark_bfs[xin.x][xin.y] = 1;
q.push(xin);
if(map[xin.x][xin.y] == '@')
dis[key][0] = xin.t;
if(map[xin.x][xin.y] == '<')
dis[key][nn+1] = xin.t;
if(map[xin.x][xin.y] >= 'A' && map[xin.x][xin.y] <= 'J')
dis[key][map[xin.x][xin.y] - 64] = xin.t;
}
}
}
return ;
}
void DFS(int s ,int time ,int mon) // s是当前点 ,time是当前所用时间,mon是当前财
//富值
{
if(time > tt || mm == ss) return;
if(s == nn + 1 && mm < mon)
mm = mon;
for(int k = 1 ;k <= nn + 1 ;k ++)
{
if(!dis[s][k] || mark_dfs[k]) continue;
mark_dfs[k] = 1;
DFS(k ,time + dis[s][k] ,mon + money[k]);
mark_dfs[k] = 0;
}
}
int main ()
{
int i ,j ,t ,cas = 1;
scanf("%d" ,&t);
while(t--)
{
scanf("%d %d %d %d" ,&yy ,&xx ,&tt ,&nn);
money[0] = money[nn+1] = 0;
for(ss = 0 ,i = 1 ;i <= nn ;i ++)
{
scanf("%d" ,&money[i]);
ss += money[i];
}
for(i = 0 ;i < xx ;i ++)
scanf("%s" ,map[i]);
memset(dis ,0 ,sizeof(dis));
for(i = 0 ;i < xx ;i ++)
for(j = 0 ;j < yy ;j ++)
{
// 起点是 0 ,终点是 n + 1 ,宝物是 1 ---- n其他的墙和路都不要了,深搜时没有用
if(map[i][j] == '*')
continue;
if(map[i][j] == '@')
BFS(i ,j ,0);
if(map[i][j] == '<')
BFS(i ,j ,nn + 1);
if(map[i][j] >= 'A' && map[i][j] <= 'J')
BFS(i ,j ,map[i][j] - 64);
}
mm = -1;
memset(mark_dfs ,0 ,sizeof(mark_dfs));
mark_dfs[0] = 1;
DFS(0 ,0 ,0);
printf("Case %d:\n" ,cas ++);
if(mm == -1)
printf("Impossible\n");
else
printf("The best score is %d.\n" ,mm);
if(t) printf("\n");
}
return 0;
}
hdu 1044 BFS(压缩图)+DFS的更多相关文章
- hdu 1044(bfs+dfs+剪枝)
Collect More Jewels Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Othe ...
- HDU 1983 BFS&&DFS
大多数刚需封锁4区域可以,DFS地区封锁.BFS无论是通过 #include "stdio.h" #include "string.h" #include &q ...
- hdu 1044(bfs+状压)
非常经典的一类题型 没有多个出口.这里题目没有说清楚 Collect More Jewels Time Limit: 2000/1000 MS (Java/Others) Memory Limi ...
- HDU 1044 BFS
Collect More Jewels Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Othe ...
- HDU 1044 Collect More Jewels(BFS+DFS)
Collect More Jewels Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Othe ...
- 列出连通集(DFS及BFS遍历图) -- 数据结构
题目: 7-1 列出连通集 (30 分) 给定一个有N个顶点和E条边的无向图,请用DFS和BFS分别列出其所有的连通集.假设顶点从0到N−1编号.进行搜索时,假设我们总是从编号最小的顶点出发,按编号递 ...
- CF467D Fedor and Essay 建图DFS
Codeforces Round #267 (Div. 2) CF#267D D - Fedor and Essay D. Fedor and Essay time limit per test ...
- HDU 1241 Oil Deposits --- 入门DFS
HDU 1241 题目大意:给定一块油田,求其连通块的数目.上下左右斜对角相邻的@属于同一个连通块. 解题思路:对每一个@进行dfs遍历并标记访问状态,一次dfs可以访问一个连通块,最后统计数量. / ...
- hdu 1241 Oil Deposits(DFS求连通块)
HDU 1241 Oil Deposits L -DFS Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & ...
随机推荐
- 【pytest官方文档】解读fixtures - 1.什么是fixtures
在深入了解fixture之前,让我们先看看什么是测试. 一.测试的构成 其实说白了,测试就是在特定的环境.特定的场景下.执行特定的行为,然后确认结果与期望的是否一致. 就拿最常见的登录来说,完成一次正 ...
- Hi3559AV100外接UVC/MJPEG相机实时采图设计(三):V4L2接口通过MPP平台输出
可以首先参考前面两篇文章: Hi3559AV100外接UVC/MJPEG相机实时采图设计(一):Linux USB摄像头驱动分析: https://www.cnblogs.com/iFrank/p/1 ...
- Salesforce LWC学习(三十一) Quick Action适配
本篇参考:https://www.lightningdesignsystem.com/components/modals/ 随着salesforce lwc的优化,越来越多的项目从aura转到了lwc ...
- jquery ajax error 函数的参数及使用
使用jquery的ajax方法向服务器发送请求的时候,可选的回调函数有success.complete.beforeSend.error函数等.error函数常用来进行错误信息的处理,这里着重提一下e ...
- 掌握HTTP原理
URI和URL URI的全程为Uniform Resource identifier,即统一资源标志符,URL的全称 Universal Resource Locator 即统一资源定位符 在目前的互 ...
- Raft共识算法详解
Raft共识算法 一.背景 拜占庭将军问题是分布式领域最复杂.最严格的容错模型.但在日常工作中使用的分布式系统面对的问题不会那么复杂,更多的是计算机故障挂掉了,或者网络通信问题而没法传递信息,这种情况 ...
- gtk中构件添加背景图
在gtk中我们总想要去给构件添加背景图,具体函数代码如下 void chang_background(GtkWidget *widget, int w, int h, const gcha r *pa ...
- Python 随笔2-0319
一 数据类型 1.整型-int 类型 存年龄.工资.成绩等这样的数据类型可以用int类型 2.浮点型-小数类型(float),带小数点的 3.布尔类型-非真即假 只有这二种:True和Flase, ...
- 攻防世界 reverse babymips
babymips XCTF 4th-QCTF-2018 mips,ida中想要反编译的化需要安装插件,这题并不复杂直接看mips汇编也没什么难度,这里我用了ghidra,直接可以查看反编译. 1 ...
- OO_Unit2 关于性能优化与测试的那些事
OO_Unit2 关于性能优化与测试的那些事 OO的第2单元到本周也就正式完结了.尽管这个单元的主旋律是多线程,但"面向对象"的基本思想仍然是我们一切架构与优化的出发点与前提.因此 ...