青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

HDOJ 1175 連連看 廣度優先搜索

Problem Description
“連連看”相信很多人都玩過。沒玩過也沒關系,下面我給大家介紹一下游戲規則:在一個棋盤中,放了很多的棋子。如果某兩個相同的棋子,可以通過一條線連起來(這條線不能經過其它棋子),而且線的轉折次數不超過兩次,那么這兩個棋子就可以在棋盤上消去。不好意思,由于我以前沒有玩過連連看,咨詢了同學的意見,連線不能從外面繞過去的,但事實上這是錯的。現在已經釀成大禍,就只能將錯就錯了,連線不能從外圍繞過。
玩家鼠標先后點擊兩塊棋子,試圖將他們消去,然后游戲的后臺判斷這兩個方格能不能消去。現在你的任務就是寫這個后臺程序。
 

Input
輸入數據有多組。每組數據的第一行有兩個正整數n,m(0<n<=1000,0<m<1000),分別表示棋盤的行數與列數。在接下來的n行中,每行有m個非負整數描述棋盤的方格分布。0表示這個位置沒有棋子,正整數表示棋子的類型。接下來的一行是一個正整數q(0<q<50),表示下面有q次詢問。在接下來的q行里,每行有四個正整數x1,y1,x2,y2,表示詢問第x1行y1列的棋子與第x2行y2列的棋子能不能消去。n=0,m=0時,輸入結束。
注意:詢問之間無先后關系,都是針對當前狀態的!
 

Output
每一組輸入數據對應一行輸出。如果能消去則輸出"YES",不能則輸出"NO"。
 

Sample Input
3 4
1 2 3 4
0 0 0 0
4 3 2 1
4
1 1 3 4
1 1 2 4
1 1 3 3
2 1 2 4
3 4
0 1 4 3
0 2 4 1
0 0 0 0
2
1 1 2 4
1 3 2 3
0 0
 

Sample Output
YES
NO
NO
NO
NO
YES
    一看題目就知道是用bfs,但是要注意幾個問題:bfs是按層次進行搜索,得到的從起點到終點的路徑(如果存在的話)是最短的。題目中說這條路徑最多只能轉向2次,有一些情況可能得到了從起點到終點的路徑,但是它的轉向次數已經超過的2次,這樣這條路徑就不符合要求,得重新找一條。一個一般的結論:如果某一點記錄的轉向次數大于當前路徑在該點的轉向次數,那么還能從該點再發出一條路徑來查找。可以用一個二維數組hash[n][n]來狀態判重,這個數組里存的數值就是某條路徑在該點的轉向次數,if(hash[x][y]>=now.turn) q.push(now);還有個需要注意的就是能連上的點并沒有從圖中消失,所以每條查詢語句都是獨立的。(我把它當成真正的連連看來做,結果WA了10次)
 1 #include <iostream>
 2 #include <queue>
 3 using namespace std;
 4 
 5 const int N = 1001;
 6 bool flag;
 7 int n,m,sx,sy,ex,ey;
 8 int hash[N][N],map[N][N];
 9 int dir[4][2]={{1,0},{0,1},{-1,0},{0,-1}};
10 struct node{
11     int x,y,turn,d;
12 }start;
13 queue<node> q;
14 
15 inline bool in(const node &p){
16     if(p.x<0 || p.y<0 || p.x>=|| p.y>=m)
17         return false;
18     return true;
19 }
20 void bfs(){
21     node now,t;
22     while(!q.empty()){
23         now=q.front(),q.pop();
24         if(now.x==ex && now.y==ey && now.turn<=2){
25             flag=true;
26             return;
27         }
28         for(int i=0;i<4;i++){
29             t.x=now.x+dir[i][0],t.y=now.y+dir[i][1];
30             if(now.d==i)
31                 t.turn=now.turn,t.d=now.d;
32             else
33                 t.turn=now.turn+1,t.d=i;
34             if(in(t) && (map[t.x][t.y]==0||t.x==ex&&t.y==ey) && hash[t.x][t.y]>=t.turn)
35                 hash[t.x][t.y]=t.turn,q.push(t);
36         }
37     }
38 }
39 int main(){
40     int i,j,t;
41     while(scanf("%d %d",&n,&m),n||m){
42         for(i=0;i<n;i++)
43             for(j=0;j<m;j++) scanf("%d",&map[i][j]);
44         scanf("%d",&t);
45         while(t--){
46             scanf("%d %d %d %d",&sx,&sy,&ex,&ey);
47             sx--,sy--,ex--,ey--;
48             if((map[sx][sy]!=map[ex][ey]) || map[sx][sy]==0 || map[ex][ey]==0 || (sx==ex&&sy==ey)){
49                 puts("NO");
50                 continue;
51             }
52             for(i=0;i<n;i++)
53                 for(j=0;j<m;j++) hash[i][j]=11;
54             while(!q.empty()) q.pop();
55             for(i=0;i<4;i++){
56                 start.x=sx,start.y=sy,start.turn=0,start.d=i;
57                 q.push(start);
58             }
59             flag=false,hash[sx][sy]=0;
60             bfs();
61             puts(flag ? "YES":"NO");
62         }
63     }
64     return 0;
65 }

posted on 2009-04-29 21:47 極限定律 閱讀(3704) 評論(3)  編輯 收藏 引用 所屬分類: ACM/ICPC

評論

# re: HDOJ 1175 連連看 廣度優先搜索 2009-10-21 00:27 Tennie

呃~~光憑這個流量量我就要膜拜下~~  回復  更多評論   

# re: HDOJ 1175 連連看 廣度優先搜索 2010-07-23 21:40 小貝

搞ACM有沒前途。請教博主。  回復  更多評論   

# re: HDOJ 1175 連連看 廣度優先搜索 2013-12-09 17:59 wuxinlilei

@小貝
不能功利,獲獎是很難的,但是對于編程能力的提高和知識的積累是很有用的  回復  更多評論   

<2009年4月>
2930311234
567891011
12131415161718
19202122232425
262728293012
3456789

導航

統計

常用鏈接

留言簿(10)

隨筆分類

隨筆檔案

友情鏈接

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            91久久精品一区| 欧美v国产在线一区二区三区| 午夜精品久久久久久久久久久久| 亚洲乱码久久| 一区二区三区四区精品| 亚洲一区二区三区四区五区午夜| 亚洲尤物在线视频观看| 亚洲一区二区在线免费观看| 久久婷婷激情| 久久蜜臀精品av| 鲁大师成人一区二区三区| 蜜桃av久久久亚洲精品| 亚洲国产精品一区制服丝袜| 亚洲第一级黄色片| 亚洲少妇最新在线视频| 欧美亚洲免费高清在线观看| 麻豆精品在线播放| 国产精品swag| 狠狠色噜噜狠狠狠狠色吗综合| 亚洲人成在线播放| 午夜国产精品视频免费体验区| 久久久精品国产免费观看同学| 欧美国产免费| 亚洲一区二区三区午夜| 老**午夜毛片一区二区三区| 国产精品hd| 亚洲国产精品传媒在线观看| 亚洲一区在线免费| 欧美激情一区二区久久久| 中文精品99久久国产香蕉| 久久久激情视频| 欧美日韩综合网| 亚洲第一福利在线观看| 欧美一区二区视频在线| 亚洲精品乱码久久久久| 久久视频精品在线| 欧美午夜精品电影| 亚洲破处大片| 久久影视精品| 亚洲永久免费观看| 欧美日韩国产小视频| 悠悠资源网亚洲青| 久久精品免费电影| 亚洲综合色婷婷| 欧美视频一二三区| 亚洲人体偷拍| 欧美丰满少妇xxxbbb| 久久福利电影| 国产欧美在线观看一区| 亚洲尤物精选| 在线亚洲一区观看| 欧美日韩另类一区| 一本大道久久a久久精品综合 | 亚洲视屏在线播放| 欧美二区不卡| 老司机一区二区三区| 韩国女主播一区二区三区| 欧美在线不卡视频| 亚洲婷婷在线| 国产精品免费一区二区三区观看| 一本久久青青| aa亚洲婷婷| 国产精品超碰97尤物18| 亚洲综合二区| 性xx色xx综合久久久xx| 国产一区二区三区在线观看免费| 久久经典综合| 亚洲国产精品va在线观看黑人 | 亚洲专区国产精品| 国产精品久久一卡二卡| 香蕉成人伊视频在线观看| 亚洲四色影视在线观看| 国产精品高清网站| 欧美一区二区三区视频| 欧美影院久久久| 亚洲电影免费观看高清完整版在线观看 | 狠狠狠色丁香婷婷综合久久五月| 久久久av毛片精品| 久久嫩草精品久久久精品一| 伊人一区二区三区久久精品| 欧美成人国产一区二区| 欧美国产欧美亚州国产日韩mv天天看完整| 91久久精品一区| 999在线观看精品免费不卡网站| 欧美日韩你懂的| 久久国产66| 欧美大片网址| 欧美一区二区三区精品| 欧美在线免费观看视频| 亚洲精品在线三区| 亚洲性感激情| 亚洲韩日在线| 亚洲特级片在线| 亚洲国产精品电影| 一区二区三区精品视频| 精品成人免费| 一区二区欧美在线| 亚洲福利国产| 性亚洲最疯狂xxxx高清| 亚洲美女在线观看| 久久www成人_看片免费不卡| 99视频超级精品| 久久久国产精品一区二区中文| 一区二区三区四区在线| 久久久久久一区| 午夜精品福利在线观看| 欧美a级一区二区| 久久久久久亚洲精品杨幂换脸 | 国产精品一区2区| 亚洲第一页自拍| 国产日韩三区| 日韩视频在线观看| 亚洲国产精品va在线观看黑人| 亚洲欧美激情一区二区| 夜夜嗨av一区二区三区四季av| 久久精品99国产精品| 午夜精品美女自拍福到在线| 99视频一区二区三区| 国外成人在线| 亚洲午夜精品网| 日韩视频专区| 久久综合九色综合网站| 久久精品99久久香蕉国产色戒| 欧美日韩国语| 亚洲精品日韩在线| 亚洲人成亚洲人成在线观看| 久久九九全国免费精品观看| 欧美一区二区视频在线| 国产精品看片你懂得| 99国产一区| 日韩一级大片在线| 欧美福利网址| 亚洲国产精品悠悠久久琪琪| 亚洲国产mv| 免费日韩一区二区| 欧美福利在线观看| 亚洲韩国一区二区三区| 久久综合一区二区三区| 欧美大片专区| 亚洲精品欧美激情| 欧美日本中文字幕| 一区二区三区久久久| 亚洲综合精品自拍| 国产麻豆精品视频| 欧美在线一二三区| 欧美a级一区| 日韩视频免费大全中文字幕| 欧美日韩卡一卡二| 亚洲网站在线播放| 欧美在线观看你懂的| 国内视频一区| 老司机午夜精品视频| 亚洲国产精品黑人久久久| 夜夜精品视频| 国产精品香蕉在线观看| 久久精品官网| 91久久精品国产91久久性色tv| 日韩视频三区| 国产乱码精品一区二区三区av| 久久国产精品久久国产精品 | 欧美一区2区三区4区公司二百| 国产日韩欧美在线| 暖暖成人免费视频| 中日韩高清电影网| 久久先锋影音av| 亚洲免费观看| 国产视频在线观看一区| 欧美国产欧美亚州国产日韩mv天天看完整 | 欧美国产一区视频在线观看| 亚洲日本欧美日韩高观看| 亚洲欧美日韩中文播放| 国内精品久久久久影院 日本资源 国内精品久久久久伊人av | 亚洲国产精品专区久久| 亚洲中无吗在线| 国产在线高清精品| 欧美精品粉嫩高潮一区二区| 午夜视频在线观看一区二区三区 | 中文在线资源观看网站视频免费不卡 | 国产精品日韩专区| 久久久久久一区| 国产精品99久久久久久久久久久久| 欧美一区日本一区韩国一区| 亚洲国产精品久久| 国产精品一区久久久久| 欧美国产日本高清在线| 亚洲欧美国产三级| 亚洲精品乱码久久久久久黑人| 久久精品九九| 亚洲欧美精品suv| 91久久嫩草影院一区二区| 国产女主播一区| 欧美日韩免费一区二区三区视频 | 欧美成人精品激情在线观看| 亚洲影音一区| 99re8这里有精品热视频免费 | 欧美一站二站| 一区二区三区导航| 亚洲精品视频免费观看| 狠狠做深爱婷婷久久综合一区| 国产精品日韩欧美一区二区三区|