FZU 2150 Fire Game (暴力BFS)
【题目链接】click here~~
【题目大意】:
两个熊孩子要把一个正方形上的草都给烧掉,他俩同一时候放火烧。烧第一块的时候是不花时间的。每一块着火的都能够在下一秒烧向上下左右四块#代表草地,.代表着不能烧的。问你最少花多少时间能够烧掉。假设烧不掉就输出-1
【解题思路】:
数据比較弱的情况下直接暴力枚举每块草坪上能够放的位置,比較高端的写法眼下没有想到。以后想到了文章更新下~~
ps:因为一个细节没注意,导致WA了差点儿一页,还以为FZU 判题出错了。后来突然发现每次从队列里拿出队首的元素,才是和maxx比較时间的最大可能!
代码:
- //FZU 2150
- #ifndef _GLIBCXX_NO_ASSERT
- #include <cassert>
- #endif
- #include <cctype>
- #include <cerrno>
- #include <cfloat>
- #include <ciso646>
- #include <climits>
- #include <clocale>
- #include <cmath>
- #include <csetjmp>
- #include <csignal>
- #include <cstdarg>
- #include <cstddef>
- #include <cstdio>
- #include <cstdlib>
- #include <cstring>
- #include <ctime>
- // C++
- #include <algorithm>
- #include <bitset>
- #include <complex>
- #include <deque>
- #include <exception>
- #include <fstream>
- #include <functional>
- #include <iomanip>
- #include <ios>
- #include <iosfwd>
- #include <iostream>
- #include <istream>
- #include <iterator>
- #include <limits>
- #include <list>
- #include <locale>
- #include <map>
- #include <memory>
- #include <new>
- #include <numeric>
- #include <ostream>
- #include <queue>
- #include <set>
- #include <sstream>
- #include <stack>
- #include <stdexcept>
- #include <streambuf>
- #include <string>
- #include <typeinfo>
- #include <utility>
- #include <valarray>
- #include <vector>
- using namespace std;
- #define rep(i,j,k) for(int i=(int)j;i<(int)k;++i)
- #define per(i,j,k) for(int i=(int)j;i>(int)k;--i)
- #define lowbit(a) a&-a
- #define Max(a,b) a>b?a:b
- #define Min(a,b) a>b?b:a
- #define mem(a,b) memset(a,b,sizeof(a))
- typedef long long LL;
- typedef unsigned long long LLU;
- typedef double db;
- const int N=105;
- const int inf=0x3f3f3f3f;
- int n,m,T;
- char mat[25][25];
- bool vis[N][N];
- int dir4[4][2]= {{1,0},{0,1},{-1,0},{0,-1}};
- int dir8[8][2]= {{1,0},{1,1},{0,1},{-1,1},{-1,0},{-1,-1},{0,-1},{1,-1}};
- int dir6[6][3]= {{0,0,1},{0,0,-1},{0,1,0},{0,-1,0},{1,0,0},{-1,0,0}};///六个方向
- struct node
- {
- int Coor_x;
- int Coor_y;
- int step;
- } q,p,mapp[N];
- bool ok(int dx,int dy)
- {
- if(dx>=0&&dx<n&&dy>=0&&dy<m) return true;
- return false;
- }
- int ans;
- void getMat()
- {
- ans=0;
- for(int i=0; i<n; ++i){
- scanf("%s",mat[i]);
- for(int j=0; j<m; ++j){
- if(mat[i][j]=='#'){
- ans++;
- mapp[ans].Coor_x=i;
- mapp[ans].Coor_y=j;
- }
- }
- }
- }
- int bfs(int x1,int y1,int x2,int y2)
- {
- int maxx=0;
- q.Coor_x=x1,q.Coor_y=y1,q.step=0;
- p.Coor_x=x2,p.Coor_y=y2,p.step=0;
- queue <node> vall;
- vall.push(q);
- vall.push(p);
- while(!vall.empty()){
- node q1,p1=vall.front();
- vall.pop();
- for(int i=0; i<4; ++i){
- int dx=p1.Coor_x+dir4[i][0];
- int dy=p1.Coor_y+dir4[i][1];
- if(ok(dx,dy)&&!vis[dx][dy]&&mat[dx][dy]=='#'){
- vis[dx][dy]=true;
- q1.Coor_x=dx;
- q1.Coor_y=dy;
- q1.step=p1.step+1;
- vall.push(q1);
- }
- }
- maxx=Max(maxx,p1.step);///大坑。,注意和vall.front() 比較
- }
- return maxx;
- }
- int main()
- {
- scanf("%d",&T);
- int tot=1;
- while(T--){
- scanf("%d%d",&n,&m);
- getMat();
- printf("Case %d: ",tot++);
- if(ans<=2){
- puts("0");
- continue;
- }
- int minn=inf;
- for(int i=0; i<ans; ++i){
- for(int j=i; j<ans; ++j){
- mem(vis,false);
- vis[mapp[i].Coor_x][mapp[i].Coor_y]=true;
- vis[mapp[j].Coor_x][mapp[j].Coor_y]=true;
- bool flag=false;
- int _minn=bfs(mapp[i].Coor_x,mapp[i].Coor_y,mapp[j].Coor_x,mapp[j].Coor_y);
- for(int k=0; k<n; ++k){
- for(int l=0; l<m; ++l){
- if(mat[k][l]!='#') continue;
- if(!vis[k][l]){
- flag=true;
- break;
- }
- }
- }
- if(!flag) minn=Min(_minn,minn);
- }
- }
- if(minn==inf) puts("-1");
- else printf("%d\n",minn);
- }
- return 0;
- }
FZU 2150 Fire Game (暴力BFS)的更多相关文章
- FZU 2150 fire game (bfs)
Problem 2150 Fire Game Accept: 2133 Submit: 7494Time Limit: 1000 mSec Memory Limit : 32768 KB ...
- FZU 2150 Fire Game(BFS)
点我看题目 题意 :就是有两个熊孩子要把一个正方形上的草都给烧掉,他俩同时放火烧,烧第一块的时候是不花时间的,每一块着火的都可以在下一秒烧向上下左右四块#代表草地,.代表着不能烧的.问你最少花多少时间 ...
- FZU 2150 Fire Game(点火游戏)
FZU 2150 Fire Game(点火游戏) Time Limit: 1000 mSec Memory Limit : 32768 KB Problem Description - 题目描述 ...
- fzu 2150 Fire Game 【身手BFS】
称号:fzupid=2150"> 2150 Fire Game :给出一个m*n的图,'#'表示草坪,' . '表示空地,然后能够选择在随意的两个草坪格子点火.火每 1 s会向周围四个 ...
- FZU 2150 Fire Game
Fire Game Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit St ...
- (FZU 2150) Fire Game (bfs)
题目链接:http://acm.fzu.edu.cn/problem.php?pid=2150 Problem Description Fat brother and Maze are playing ...
- foj 2150 Fire Game(bfs暴力)
Problem Description Fat brother and Maze are playing a kind of special (hentai) game on an N*M ...
- FZU 2150 Fire Game 广度优先搜索,暴力 难度:0
http://acm.fzu.edu.cn/problem.php?pid=2150 注意这道题可以任选两个点作为起点,但是时间仍足以穷举两个点的所有可能 #include <cstdio> ...
- FZU Problem 2150 Fire Game(bfs)
这个题真要好好说一下了,比赛的时候怎么过都过不了,压点总是出错(vis应该初始化为inf,但是我初始化成了-1....),wa了n次,后来想到完全可以避免这个问题,只要入队列的时候判断一下就行了. 由 ...
随机推荐
- QT+模态对话框与非模态对话框
#include "mainwindow.h" #include <QMenuBar> #include <QMenu> #include <QAct ...
- vueshengmingzhouqi
首先,每个Vue实例在被创建之前都要经过一系列的初始化过程,这个过程就是vue的生命周期.首先看一张图吧~这是官方文档上的图片相信大家一定都会很熟悉: 可以看到在vue一整个的生命周期中会有很多钩子函 ...
- [LOJ] 分块九题 3
https://loj.ac/problem/6279 区间修改,区间查询前驱. TLE无数,我觉得这代码最精髓的就是block=1000. 谜一样的1000. 两个启示: 块内可以维护数据结构,比如 ...
- Linux硬盘的检测--smartctl详细介绍
概述 随着硬盘容量.速度的快速发展,硬盘的可靠性问题越来越重要,今天的单块硬盘存储容量可轻松达到1TB,硬盘损坏带来的影响非常巨大.不同的文件系统(xfs,reiserfs,ext3)都有自己的检测 ...
- logging日志模块配置
logging日志模块 日志级别 日志一共分成5个等级,从低到高分别是: 1)DEBUG 2)INFO 3)WARNING 4)ERROR 5)CRITICAL 说明: DEBUG:详细的信息,通常只 ...
- 安装完Centos 7后的一些处理
1.安装dkms:dkms-2.2.0.3-31.1.noarch.rpm 2.安装显卡驱动:amdgpu-pro-18.10-572953 3.启动图形界面使用init 5 不能使用startx
- 用spring annotation声明的bean,当打包在jar中时,无法被扫描到
发现一个问题,十分蛋疼. 我们项目是由N个工程组成的,外围工程是web工程,内部的工程打包成jar,放入外围工程的WEB-INF/lib 内部的工程用到了spring的注解,例如@Service.@C ...
- 安装weblogic时,运行configure.cmd报错、闪退、无法创建域
直接运行configure.cmd时在jar包加载完成时,不提示创建域的过程,而是直接退出程序 命令行: cd /d F:\00uep_rfs\wls1212_dev\wls12120 切换至解压路径 ...
- HDU1711 最基础的kmp算法
Problem Description Given two sequences of numbers : a[1], a[2], ...... , a[N], and b[1], b[2], .... ...
- NOIP2013D1T3货车运输(最大生成树+倍增lca)
传送门 这道题,先用kruskal求一遍图中的最大生成树. 然后,倍增求lca,求lca的同时求出边权的最小值. #include <cstring> #include <cstdi ...