MAGCARI

COI Board Game

Feb 8th, 2023 (edited)
791
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.47 KB | None | 0 0
  1. /*
  2.     Task    : _example
  3.     Author  : Phumipat C. [MAGCARI]
  4.     Language: C++
  5.     Created : 15 February 2023 [19:54]
  6.     Algo    :
  7.     Status  :
  8. */
  9. #include<bits/stdc++.h>
  10. using namespace std;
  11. struct A{
  12.     int i,j,mask;
  13. };
  14. queue<A > que;
  15. char a[510][510];
  16. int dis[510][510][10];
  17. int dir[2][4] = {{-1,1,0,0},{0,0,1,-1}};
  18. int main(){
  19.     int n,m,sti,stj;
  20.     scanf("%d %d",&n,&m);
  21.     for(int i=1;i<=n;i++){
  22.         for(int j=1;j<=m;j++){
  23.             scanf(" %c",&a[i][j]);
  24.             if(a[i][j] == 'S')
  25.                 sti = i,stj = j;
  26.         }
  27.     }
  28.     for(int i=1;i<=n;i++)
  29.         for(int j=1;j<=m;j++)
  30.             for(int k=0;k<8;k++)
  31.                         dis[i][j][k] = 1e9;
  32.     dis[sti][stj][0] = 0;
  33.     que.push({sti,stj,0});
  34.     while(!que.empty()){
  35.         A now = que.front();
  36.         que.pop();
  37.         if(a[now.i][now.j] == 'E'){
  38.             printf("%d\n",dis[now.i][now.j][now.mask]);
  39.             return 0;
  40.         }
  41.         for(int k=0;k<4;k++){
  42.             int ni = now.i+dir[0][k],nj = now.j+dir[1][k];
  43.             if(ni<1 || ni>n || nj<1 || nj>m)    continue;
  44.             if(a[ni][nj] == '#')                continue;
  45.             if(a[ni][nj] == 'J' && (now.mask & (1<<0)) == 0)    continue;
  46.             if(a[ni][nj] == 'B' && (now.mask & (1<<1)) == 0)    continue;
  47.             if(a[ni][nj] == 'P' && (now.mask & (1<<2)) == 0)    continue;
  48.             int nmask = now.mask;
  49.             if(a[ni][nj] == 'j')    nmask |= (1<<0);
  50.             if(a[ni][nj] == 'b')    nmask |= (1<<1);
  51.             if(a[ni][nj] == 'p')    nmask |= (1<<2);
  52.             if(dis[ni][nj][nmask] > dis[now.i][now.j][now.mask]+1){
  53.                 dis[ni][nj][nmask] = dis[now.i][now.j][now.mask]+1;
  54.                 que.push({ni,nj,nmask});
  55.             }
  56.         }
  57.     }
  58.     printf("-1\n");
  59.     return 0;
  60. }
Advertisement
Add Comment
Please, Sign In to add comment