zoukankan      html  css  js  c++  java
  • HDU1180+BFS

    bfs
    思路:三维标记状态 && 处理好 - | 和时刻的关系即可

      1 /*
      2 bfs
      3 思路:三维标记状态 && 处理好 - | 和时刻的关系即可
      4 */
      5 #include<algorithm>  
      6 #include<iostream>  
      7 #include<string.h>  
      8 #include<stdlib.h>  
      9 #include<stdio.h>  
     10 #include<math.h>  
     11 #include<queue>  
     12 #include<stack>  
     13 #include<map>  
     14 #include<set>  
     15 using namespace std;  
     16 typedef long long int64;  
     17 //typedef __int64 int64;  
     18 typedef pair<int64,int64> PII;  
     19 #define MP(a,b) make_pair((a),(b))   
     20 const int inf = 0x3f3f3f3f;  
     21 const double pi=acos(-1.0);  
     22 const int dx[]={1,-1,0,0};  
     23 const int dy[]={0,0,1,-1};  
     24 const double eps = 1e-8;  
     25 const int maxm = 1005;  
     26 const int maxn = 25;  
     27 
     28 struct Point {
     29     int x,y,t;
     30 };
     31 Point s,e;
     32 
     33 bool vis[ maxn ][ maxn ][ 2 ];
     34 char mat[ maxn ][ maxn ];
     35 queue<Point>q;
     36 
     37 int bfs( int n,int m ){
     38     memset( vis,false,sizeof( vis ) );
     39     while( !q.empty() )
     40         q.pop();
     41     Point cur = s;
     42     vis[ s.x ][ s.y ][ s.t%2 ] = true;
     43     q.push( cur );
     44     while( !q.empty() ){
     45         cur = q.front();
     46         q.pop();
     47         //printf("
    cur:[%d,%d] t = %d
    ",cur.x,cur.y,cur.t);
     48         if( cur.x==e.x && cur.y==e.y ){
     49             e.t = min( e.t,cur.t );
     50         }
     51         if( cur.t>=e.t ) continue;
     52         for( int i=0;i<4;i++ ){
     53             Point nxt;
     54             nxt.x = cur.x + dx[ i ];
     55             nxt.y = cur.y + dy[ i ];
     56             nxt.t = cur.t + 1;
     57             if( nxt.x<0||nxt.x>=n||nxt.y<0||nxt.y>=m ) continue;
     58             if( mat[ nxt.x ][ nxt.y ]=='*' ) continue;
     59             if( mat[ nxt.x ][ nxt.y ]=='.' ){
     60                 if( vis[ nxt.x ][ nxt.y ][ nxt.t%2 ]==true ) continue;
     61                 vis[ nxt.x ][ nxt.y ][ nxt.t%2 ] = true;
     62                 q.push( nxt );
     63                 //printf("0 nxt:[%d,%d] t = %d
    ",nxt.x,nxt.y,nxt.t);
     64                 continue;
     65             }//
     66             nxt.x = cur.x + dx[ i ];
     67             nxt.y = cur.y + dy[ i ];
     68             nxt.t = cur.t + 1;
     69             if(( mat[ nxt.x ][ nxt.y ]=='-'&&cur.t%2==0 )||( mat[ nxt.x ][ nxt.y ]=='|'&&cur.t%2==1 )){
     70                 if( cur.x==nxt.x&&nxt.y>cur.y ) nxt.y = cur.y + 2;
     71                 if( cur.x==nxt.x&&nxt.y<cur.y ) nxt.y = cur.y - 2;
     72                 if( nxt.x>=0&&nxt.x<n&&nxt.y>=0&&nxt.y<m&&mat[ nxt.x ][ nxt.y ]=='.' ){
     73                     if( vis[ nxt.x ][ nxt.y ][ nxt.t%2 ]==false ){
     74                         vis[ nxt.x ][ nxt.y ][ nxt.t%2 ] = true;
     75                         q.push( nxt );
     76                         //printf("1 nxt:[%d,%d] t = %d
    ",nxt.x,nxt.y,nxt.t);
     77                         continue;
     78                     }
     79                 }
     80             }//1 ‘-’ 上下无需等待时间
     81             nxt.x = cur.x + dx[ i ];
     82             nxt.y = cur.y + dy[ i ];
     83             nxt.t = cur.t + 1;
     84             /*恢复nxt很重要*/
     85             if(( mat[ nxt.x ][ nxt.y ]=='-'&&cur.t%2==1 )||( mat[ nxt.x ][ nxt.y ]=='|'&&cur.t%2==0 )){
     86                 nxt.t = cur.t + 2;
     87                 if( cur.x==nxt.x&&nxt.y>cur.y ) nxt.y = cur.y + 2;
     88                 if( cur.x==nxt.x&&nxt.y<cur.y ) nxt.y = cur.y - 2;
     89                 if( nxt.x>=0&&nxt.x<n&&nxt.y>=0&&nxt.y<m&&mat[ nxt.x ][ nxt.y ]=='.' ){
     90                     if( vis[ nxt.x ][ nxt.y ][ nxt.t%2 ]==false ){
     91                         vis[ nxt.x ][ nxt.y ][ nxt.t%2 ] = true;
     92                         q.push( nxt );
     93                         //printf("2 nxt:[%d,%d] t = %d
    ",nxt.x,nxt.y,nxt.t);
     94                         continue;
     95                     }
     96                 }
     97             }//2 ‘-’ 上下需要等待时间
     98             nxt.x = cur.x + dx[ i ];
     99             nxt.y = cur.y + dy[ i ];
    100             nxt.t = cur.t + 1;
    101             /*恢复nxt很重要*/
    102             if(( mat[ nxt.x ][ nxt.y ]=='|'&&cur.t%2==0 )||( mat[ nxt.x ][ nxt.y ]=='-'&&cur.t%2==1 )){
    103                 if( cur.y==nxt.y&&nxt.x>cur.x ) nxt.x = cur.x + 2;
    104                 if( cur.y==nxt.y&&nxt.x<cur.x ) nxt.x = cur.x - 2;
    105                 if( nxt.x>=0&&nxt.x<n&&nxt.y>=0&&nxt.y<m&&mat[ nxt.x ][ nxt.y ]=='.' ){
    106                     if( vis[ nxt.x ][ nxt.y ][ nxt.t%2 ]==false ){
    107                         vis[ nxt.x ][ nxt.y ][ nxt.t%2 ] = true;
    108                         q.push( nxt );
    109                         //printf("3 nxt:[%d,%d] t = %d
    ",nxt.x,nxt.y,nxt.t);
    110                         continue;
    111                     }
    112                 }
    113             }//3 ‘|’ 左右无需等待时间
    114             nxt.x = cur.x + dx[ i ];
    115             nxt.y = cur.y + dy[ i ];
    116             nxt.t = cur.t + 1;
    117             /*恢复nxt很重要*/
    118             if(( mat[ nxt.x ][ nxt.y ]=='|'&&cur.t%2==1 )||( mat[ nxt.x ][ nxt.y ]=='-'&&cur.t%2==0 )){
    119                 nxt.t = cur.t + 2;
    120                 if( cur.y==nxt.y&&nxt.x>cur.x ) nxt.x = cur.x + 2;
    121                 if( cur.y==nxt.y&&nxt.x<cur.x ) nxt.x = cur.x - 2;
    122                 if( nxt.x>=0&&nxt.x<n&&nxt.y>=0&&nxt.y<m&&mat[ nxt.x ][ nxt.y ]=='.' ){
    123                     if( vis[ nxt.x ][ nxt.y ][ nxt.t%2 ]==false ){
    124                         vis[ nxt.x ][ nxt.y ][ nxt.t%2 ] = true;
    125                         q.push( nxt );
    126                         //printf("4 nxt:[%d,%d] t = %d
    ",nxt.x,nxt.y,nxt.t);
    127                         continue;
    128                     }
    129                 }
    130             }//4 ‘|’ 左右需要等待时间
    131         }
    132     }
    133     return e.t;
    134 }
    135      
    136 int main(){
    137     int n,m;
    138     //freopen( "in.txt","r",stdin );
    139     while( scanf("%d%d",&n,&m)==2 ){
    140         for( int i=0;i<n;i++ ){
    141             scanf("%s",mat[ i ]);
    142             for( int j=0;j<m;j++ ){
    143                 if( mat[ i ][ j ]=='S' ){
    144                     s.x = i;
    145                     s.y = j;
    146                     s.t = 0;
    147                     mat[ i ][ j ] = '.';
    148                 }
    149                 else if( mat[ i ][ j ]=='T' ){
    150                     e.x = i;
    151                     e.y = j;
    152                     e.t = inf;
    153                     mat[ i ][ j ] = '.';
    154                 }
    155             }
    156         }
    157         printf("%d
    ",bfs( n,m ));
    158     }
    159     return 0;
    160 }
    View Code
    keep moving...
  • 相关阅读:
    中缀表达式std
    后缀表达式
    取石头游戏
    LeetCode404Sum of Left Leaves左叶子之和
    LeetCode387First Unique Character in a String字符串中第一个唯一字符
    简单排列习题2.5 的 2
    周期串Uva455 P37 3-4
    【递归】分形
    【递归】普通递归关系(矩阵快速幂)
    P3486 [POI2009]KON-Ticket Inspector
  • 原文地址:https://www.cnblogs.com/xxx0624/p/3397485.html
Copyright © 2011-2022 走看看