Fire!——兩個BFS

【題目描述】
在這里插入圖片描述
【題目分析】
看到題目后很清楚是兩個BFS,可是我覺得對于火的BFS可以轉換成判斷,我的做法是將火的位置全部記錄下來,然后判斷某個位置距離每個火的步數是否小于當前步數,可是錯了,還不清楚為什么(有可能是因為沒有記憶化復雜度太高?但是為什么是wa不是超時),改成BFS后就過了
【AC代碼】

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<queue>
#include<cmath>
#include<climits>
#include<set>using namespace std;const int MAXN=1005;
int n,m,sx,sy,ans;
char map[MAXN][MAXN];
int vis[MAXN][MAXN];
struct node
{int x,y,step;
}t,p,S;
//struct node1{int x,y;}fire[MAXN*MAXN];
int Time[MAXN][MAXN];
//int cnt;
const int drc[4][2]={1,0,-1,0,0,1,0,-1};
queue<node> fire;/*
bool danger(int x,int y,int step)
{int tmp;for(int i=0;i<cnt;i++){tmp=abs(x-fire[i].x)+abs(y-fire[i].y);if(tmp<=step)return true;}return false;
}
*/void init()
{int u,v;while(!fire.empty()){p=fire.front(); fire.pop();for(int i=0;i<4;i++){u=p.x+drc[i][0]; v=p.y+drc[i][1];if(u<0 || u>n-1 || v<0 || v>m-1) continue;if(map[u][v]=='#') continue;if(p.step+1>=Time[u][v]) continue;Time[u][v]=p.step+1;t.x=u; t.y=v; t.step=p.step+1;fire.push(t);}}
}bool BFS()
{int u,v;memset(vis,0,sizeof(vis));queue<node> q;q.push(S); vis[S.x][S.y]=1;while(!q.empty()){p=q.front(); q.pop();if(p.x==0 || p.x==n-1 || p.y==0 || p.y==m-1){ans=p.step+1;return true;}for(int i=0;i<4;i++){u=p.x+drc[i][0]; v=p.y+drc[i][1];if(u<0 || u>n-1 || v<0 || v>m-1) continue;if(map[u][v]=='#' || vis[u][v]) continue;if(p.step+1>=Time[u][v]) continue;vis[u][v]=1;t.x=u; t.y=v; t.step=p.step+1;q.push(t);}}return false;
}int main()
{int T;scanf("%d",&T);while(T--){while(!fire.empty()) fire.pop();memset(map,0,sizeof(map));scanf("%d%d",&n,&m);//cnt=0; ans=0;memset(Time,0x3f,sizeof(Time));for(int i=0;i<n;i++){scanf("%s",map[i]);for(int j=0;j<m;j++){if(map[i][j]=='J'){S.x=i; S.y=j; S.step=0;map[i][j]='.';}else if(map[i][j]=='F'){//fire[cnt].x=i; fire[cnt].y=j;//map[i][j]='#';//cnt++;t.x=i; t.y=j; t.step=0;Time[i][j]=0;fire.push(t);}}}init();if(BFS()){printf("%d\n",ans);}else{printf("IMPOSSIBLE\n");}}return 0;
}

剛才記憶化了一下試了一下還是不行,并不知道為什么
【wa代碼】

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<queue>
#include<cmath>
#include<climits>
#include<set>using namespace std;const int MAXN=1005;
int n,m,sx,sy,ans;
char map[MAXN][MAXN];
int vis[MAXN][MAXN];
struct node
{int x,y,step;
}t,p,S;
struct node1{int x,y;}fire[MAXN*MAXN];
int Time[MAXN][MAXN];
int cnt;
const int drc[4][2]={1,0,-1,0,0,1,0,-1};
//queue<node> fire;/*
bool danger(int x,int y,int step)
{int tmp;for(int i=0;i<cnt;i++){tmp=abs(x-fire[i].x)+abs(y-fire[i].y);if(tmp<=step)return true;}return false;
}
*/void init()
{int u,v;/*while(!fire.empty()){p=fire.front(); fire.pop();for(int i=0;i<4;i++){u=p.x+drc[i][0]; v=p.y+drc[i][1];if(u<0 || u>n-1 || v<0 || v>m-1) continue;if(map[u][v]=='#') continue;if(p.step+1>=Time[u][v]) continue;Time[u][v]=p.step+1;t.x=u; t.y=v; t.step=p.step+1;fire.push(t);}}*/for(int i=0;i<n;i++){for(int j=0;j<m;j++){if(map[i][j]=='#') continue;for(int k=0;k<cnt;k++){Time[i][j]=min(Time[i][j],abs(i-fire[k].x)+abs(j-fire[k].y));}}}
}bool BFS()
{int u,v;memset(vis,0,sizeof(vis));queue<node> q;q.push(S); vis[S.x][S.y]=1;while(!q.empty()){p=q.front(); q.pop();if(p.x==0 || p.x==n-1 || p.y==0 || p.y==m-1){ans=p.step+1;return true;}for(int i=0;i<4;i++){u=p.x+drc[i][0]; v=p.y+drc[i][1];if(u<0 || u>n-1 || v<0 || v>m-1) continue;if(map[u][v]=='#' || vis[u][v]) continue;if(p.step+1>=Time[u][v]) continue;vis[u][v]=1;t.x=u; t.y=v; t.step=p.step+1;q.push(t);}}return false;
}void show()
{for(int i=0;i<cnt;i++){printf("%d %d\n",fire[i].x,fire[i].y);}for(int i=0;i<n;i++){for(int j=0;j<m;j++){printf("%d ",Time[i][j]);}printf("\n");}
}int main()
{int T;scanf("%d",&T);while(T--){//while(!fire.empty()) fire.pop();memset(map,0,sizeof(map));scanf("%d%d",&n,&m);cnt=0; ans=0;memset(fire,0,sizeof(fire));memset(Time,0x3f,sizeof(Time));for(int i=0;i<n;i++){scanf("%s",map[i]);for(int j=0;j<m;j++){if(map[i][j]=='J'){S.x=i; S.y=j; S.step=0;map[i][j]='.';}else if(map[i][j]=='F'){fire[cnt].x=i; fire[cnt].y=j;cnt++;//t.x=i; t.y=j; t.step=0;//Time[i][j]=0;//fire.push(t);}}}init();//show();if(BFS()){printf("%d\n",ans);}else{printf("IMPOSSIBLE\n");}}return 0;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/384151.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/384151.shtml
英文地址,請注明出處:http://en.pswp.cn/news/384151.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

函數調用過程(棧楨)

棧楨 首先來看一段代碼 #include<stdio.h> int add(int x, int y) {int z x y;return z; } int main() {int a 10;int b 20;int ret add(a, b);printf("ret %d\n",ret);return 0; } 此處是為了給a,b分別開辟空間,這時棧楨如圖所示 兩條push命令將a,b變…

C++智能指針簡單剖析

http://blog.csdn.net/lanxuezaipiao/article/details/41603883 導讀 最近在補看《C Primer Plus》第六版&#xff0c;這的確是本好書&#xff0c;其中關于智能指針的章節解析的非常清晰&#xff0c;一解我以前的多處困惑。C面試過程中&#xff0c;很多面試官都喜歡問智能指針相…

非常可樂——BFS

【題目描述】 大家一定覺的運動以后喝可樂是一件很愜意的事情&#xff0c;但是seeyou卻不這么認為。因為每次當seeyou買了可樂以后&#xff0c;阿牛就要求和seeyou一起分享這一瓶可樂&#xff0c;而且一定要喝的和seeyou一樣多。但seeyou的手中只有兩個杯子&#xff0c;它們的容…

整型數據存儲

//代碼1 #include<stdio.h> int main() {char a -1;signed char b -1;unsigned char c -1;printf("a %d, b %d, c %d", a, b, c);return 0; } 1000 0000 0000 0001 -> -1源碼 1111 1111 1111 1110 -> -1反碼 1111 1111 1111 1111 -> -1補碼 對于…

聊聊gcc參數中的-I, -L和-l

http://blog.csdn.net/stpeace/article/details/49408665 在本文中&#xff0c; 我們來聊聊gcc中三個常見的參數&#xff0c; 也即-I, -L和-l 一. 先說 -I (注意是大寫的i) 我們先來看簡單的程序&#xff1a; main.c: [cpp] view plaincopy #include <stdio.h> #incl…

Pots——BFS

【題目描述】 You are given two pots, having the volume of A and B liters respectively. The following operations can be performed: FILL(i) fill the pot i (1 ≤ i ≤ 2) from the tap; DROP(i) empty the pot i to the drain; POUR(i,j) pour from pot i to pot j;…

HDU - 4578Transformation——線段樹+區間加法修改+區間乘法修改+區間置數+區間和查詢+區間平方和查詢+區間立方和查詢

【題目描述】 HDU - 4578Transformation Problem Description Yuanfang is puzzled with the question below: There are n integers, a1, a2, …, an. The initial values of them are 0. There are four kinds of operations. Operation 1: Add c to each number between ax …

[C++基礎]034_C++模板編程里的主版本模板類、全特化、偏特化(C++ Type Traits)

http://www.cnblogs.com/alephsoul-alephsoul/archive/2012/10/18/2728753.html 1. 主版本模板類 首先我們來看一段初學者都能看懂&#xff0c;應用了模板的程序&#xff1a; 1 #include <iostream>2 using namespace std;3 4 template<class T1, class T2>5 clas…

自定義類型: 結構體,枚舉,聯合

1.結構體 個人認為結構體和數組特別相似&#xff0c;只不過結構體和數組的區別在于結構體的成員可以是不同類型&#xff0c;而數組成員類型是相同的。 &#xff08;1&#xff09;結構體的聲明 struct tag {成員列表//至少得有一個成員 }值列表;//值列表可以省略 struct {int a…

詳解C++中的函數調用和下標以及成員訪問運算符的重載

http://www.jb51.net/article/78436.htm 這篇文章主要介紹了詳解C中的函數調用和下標以及成員訪問運算符,講到了這些二元運算符使用的語法及重載,需要的朋友可以參考下函數調用 使用括號調用的函數調用運算符是二元運算符。 語法 ?1primary-expression ( expression-list )備…

A計劃——BFS

【題目描述】 可憐的公主在一次次被魔王擄走一次次被騎士們救回來之后&#xff0c;而今&#xff0c;不幸的她再一次面臨生命的考驗。魔王已經發出消息說將在T時刻吃掉公主&#xff0c;因為他聽信謠言說吃公主的肉也能長生不老。年邁的國王正是心急如焚&#xff0c;告招天下勇士…

使用openssl的md5庫

http://blog.csdn.net/sinat_35297665/article/details/78244523 在linux機器上&#xff0c;有一個命令可以計算出文件的md5值&#xff0c;那就是md5sum&#xff0c;如果沒有的話&#xff0c;就需要安裝RPM包&#xff1a;coreutils。 現在我們使用openssl的庫也可以方便的計算出…

主席樹入門

今天學習了一下主席樹&#xff08;名字這么強的嘛&#xff09; 雖然直接理解起來不容易&#xff0c;但是這種解決問題的思想其實并不陌生。 我們可以首先來看維護整個區間第K大的線段樹 我們將[l,r]區間內數字的多少用線段樹進行維護&#xff0c;這樣的話為了求取區間第k大&…

Socket網絡編程--小小網盤程序(1)

http://www.cnblogs.com/wunaozai/p/3886588.html 這個系列是準備講基于Linux Socket進行文件傳輸。簡單的文件傳輸就是客戶端可以上傳文件&#xff0c;可以從服務器端下載文件。就這么兩個功能如果再加上身份驗證&#xff0c;就成了FTP服務器了&#xff0c;如果對用戶的操作再…

使用 Verdaccio 構建自己的私有 npm 倉庫

前言 無論你是公司的開發者&#xff0c;還是個人開發者&#xff0c;你可能都聽說過或者使用過 npm&#xff0c;這是一個使用廣泛的 JavaScript 包管理器。但是&#xff0c;你是否遇到過以下的問題&#xff1a;你需要一個私有的包存放地方&#xff0c;或者你需要在離線環境下使…

HDU - 4348To the moon——主席樹+區間修改

HDU - 4348To the moon 【題目描述】 【題目分析】 題目中說明每次更新后時間都會加1&#xff0c;而且還會需要查詢以前的區間&#xff0c;還會需要返回以前的時間&#xff0c;所以是很裸的主席樹。區間查詢的話我們同樣需要用到lazy標記 通過這道題我發現線段樹的操作還是很靈…

進入一個目錄需要那些權限

1.文件訪問者的分類 文件的訪問者具體可分為以下幾類&#xff1a; (1)擁有者 (2)組擁有者 (3)其他用戶 這些都代表什么意思呢&#xff1f; 其中r表示只讀&#xff0c;w表示只寫&#xff0c;x表示可執行&#xff0c;第一個字母代表了文件的類型&#xff0c;其中文件類型可以分為…

Socket網絡編程--小小網盤程序(2)

http://www.cnblogs.com/wunaozai/p/3887728.html 這一節將不會介紹太多的技術的問題&#xff0c;這節主要是搭建一個小小的框架&#xff0c;為了方便接下來的繼續編寫擴展程序。本次會在上一小節的基礎上加上一個身份驗證的功能。 因為網盤程序不像聊天程序&#xff0c;網盤是…

Linux下的重要目錄

1.bin目錄 主要防止系統下的各種必備可執行文件 2./proc 目錄 這個目錄相當于Windows下的計算機系統信息查看以及進程動態查看&#xff0c;可以查看計算機信息&#xff0c;用來存放當前計算機上的進程信息 3./sys 目錄 (1)其中block目錄用于存放塊設備文件 (2)bus存放總線類型…

HDU - 6278 Just $h$-index主席樹+二分

HDU - 6278 Just hhh-index 【題目描述】 【題目分析】 題目要求在區間[l,r][l,r][l,r]內大于h的數不少于h個&#xff0c;對于這種最大化問題&#xff0c;我們應該想到二分。 最小情況顯然是1.最大情況顯然是r?l1r-l1r?l1&#xff0c;對于一個hhh&#xff0c;我們如何判斷能…