题目链接:uva 11561 - Getting Gold
题目大意:就是一张图,每次走到陷阱周围,为了防止调入陷阱,会停止前进,问说最多能收集多少黄金。
解题思路:bfs,将陷阱周围标记,走到就停止即可。
#include <cstdio>
#include <cstring>
#include <queue>
#include <algorithm>
using namespace std;
const int maxn = 55;
const int dir[4][2] = {{0, 1}, {0, -1}, {1, 0}, {-1, 0}};
typedef pair<int, int> pii;
int W, H, v[maxn][maxn];
char g[maxn][maxn];
void tiger (int x, int y) {
for (int i = 0; i < 4; i++) {
int p = x + dir[i][0];
int q = y + dir[i][1];
if (p < 0 || p >= H || q < 0 || q >= W)
continue;
if (v[p][q] == 0)
v[p][q] = -1;
}
}
int bfs (pii s) {
int ret = 0;
if (v[s.first][s.second] == -1)
return 0;
queue<pii> que;
que.push(s);
while (!que.empty()) {
int x = que.front().first;
int y = que.front().second;
que.pop();
for (int i = 0; i < 4; i++) {
int p = x + dir[i][0];
int q = y + dir[i][1];
if (p < 0 || p >= H || q < 0 || q >= W || v[p][q] == 1 || g[p][q] == '#')
continue;
if (v[p][q] != -1)
que.push(make_pair(p, q));
v[p][q] = 1;
if (g[p][q] == 'G')
ret++;
}
}
return ret;
}
int main () {
while (scanf("%d%d", &W, &H) == 2) {
memset(v, 0, sizeof(v));
for (int i = 0; i < H; i++)
scanf("%s", g[i]);
pii s;
for (int i = 0; i < H; i++) {
for (int j = 0; j < W; j++) {
if (g[i][j] == 'P')
s = make_pair(i, j);
else if (g[i][j] == 'T')
tiger(i, j);
}
}
printf("%d\n", bfs(s));
}
return 0;
}
分享到:
相关推荐
数据结构-DFS and BFS-PPT
a program to find Dfs and bfs
graph traversal using bfs and dfs strategy
最终效果是实现了Prim随机生成迷宫,BFS&DFS路径显示、最短路长度显示、过程动态展示,主函数中有菜单,操作方便。 不仅可以用来读代码长知识、还可以用作算法演示。 附带第五版的exe文件,欢迎使用!
// 有关 Queue 类的定义参见第 3 章 顺序表{{{}}}delete [ ] visited;}
注意遍历的结果可能不止一种深度优先DFS深度优先遍历得到的顶点序列为深度优先搜索序列(DFS序列)访问顶点v,并记录为已访问检查v的邻接点,选择尚未访问的点,不
题目:752. 打开转盘锁执行用时:204 ms, 在所有 C++ 提交中击败了40.14%的用户内存消耗:40.3 MB, 在所有 C++ 提交中击败了25.
bfs和dfs记忆化存储的数据是不一样的,dfs memo记录 从[r] [c]开始走到终点的最长距离# 记录上次走到[r][c]的时候用了几步,如果这次又走到
降群法解魔方 哈哈师大 使用双向BFS搜素
C282-DFS-BFS 班级分配-广度优先搜索和深度优先搜索2014年12月9日
leetcode BFS-1 问题一 二叉树级序遍历() 问题二 课程安排 ()
MATLAB源码集锦-基于BFS广度优先搜索算法代码
网友DSA-BFS-DFS 广度优先搜索(BFS)和广度优先遍历 广度优先搜索 (BFS)是一种探索树或图的方法。 在 BFS 中,您首先探索一步之外的所有节点,然后探索两步之外的所有节点,依此类推。 广度优先搜索就像在池塘中央...
地图管理:添加、修改、编辑、删除...知识点:BFS算法实现AI、IO流 ———————————————— 版权声明:本文为CSDN博主「刘建杰」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
algorithm-practice:算法实践-dp,bfs,dfs,分而治之,贪婪..
bfs 2. BNU 1440 --- basic dfs 3. POJ 1190 --- dfs + pruning(Strong) 4. UVALive 2243 --- dfs 5. FZU 2196 --- double bfs 6. PKU 1426 --- bfs + pruning 7. BNU 1038 --- dfs transform 8. PKU 1562 --- dfs ...
matlab广度优先算法代码搜索算法-BFS-DFS-A-star 搜索是AI中解决问题的通用技术。 这个项目将使您开始使用这些不同的算法: 蛮力搜索策略 广度优先搜索:它从根节点开始,先探索相邻节点,然后再向下一级邻居移动。 ...
leetcode BFS-2 问题一 二叉树右侧视图 () 问题二 二叉树中的表亲 ()
leetcode 2 BFS-4 问题1:扫雷() 问题2蛇和梯子()
leetcode 2 BFS-2.1 问题一 腐烂的橙子() 问题二 员工重要性()