Advertisement
Josif_tepe

Untitled

Mar 3rd, 2022
1,098
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.41 KB | None | 0 0
  1. #include <iostream>
  2. #include <vector>
  3. #include <queue>
  4. #include <algorithm>
  5. using namespace std;
  6. int prev_step[1005][1005];
  7. int main()
  8. {
  9.     ios_base::sync_with_stdio(false);
  10.     cout.tie(0);
  11.     cin.tie(0);
  12.  
  13.  
  14.  
  15.  
  16.     int n, m;
  17.     cin >> n >> m;
  18.     char mat[n][m];
  19.     bool visited[n][m];
  20.     int si, sj;
  21.     int ei, ej;
  22.     for(int i = 0; i < n; i++){
  23.         for(int j = 0; j < m; j++){
  24.             visited[i][j] = false;
  25.             cin >> mat[i][j];
  26.             if(mat[i][j] == 'A'){
  27.                 si = i;
  28.                 sj = j;
  29.             }
  30.             if(mat[i][j] == 'B') {
  31.                 ei = i;
  32.                 ej = j;
  33.             }
  34.         }
  35.     }
  36.  
  37.     cout << endl;
  38.  
  39.     queue<int> q;
  40.     q.push(si);
  41.     q.push(sj);
  42.     q.push(0);
  43.     visited[si][sj] = true;
  44.     int di[] = {1, -1, 0, 0};
  45.     int dj[] = {0, 0, 1, -1};
  46.     while(!q.empty()){
  47.         int ci = q.front();
  48.         q.pop();
  49.         int cj = q.front();
  50.         q.pop();
  51.         int dist = q.front();
  52.         q.pop();
  53.         if(mat[ci][cj] == 'B'){
  54.             break;
  55.         }
  56.      
  57.         for(int i = 0; i < 4; i++){
  58.             if(ci + di[i] < n and ci + di[i] >= 0 and cj + dj[i] < m and cj + dj[i] >= 0 and mat[ci + di[i]][cj + dj[i]] != '#' and !visited[ci + di[i]][cj + dj[i]]){
  59.                
  60.                 q.push(ci + di[i]);
  61.                 q.push(cj + dj[i]);
  62.                 q.push(dist + 1);
  63.                 prev_step[ci + di[i]][cj + dj[i]] = i;
  64.                 visited[ci + di[i]][cj + dj[i]] = true;
  65.             }
  66.         }
  67.     }
  68.  
  69.     if(visited[ei][ej]) {
  70.         cout << "YES" << endl;
  71.         pair<int, int> S = make_pair(si, sj);
  72.         pair<int, int> E = make_pair(ei, ej);
  73.         string result = "";
  74.         while(E != S) {
  75.             int p_cekor = prev_step[E.first][E.second];
  76.             if(p_cekor == 0) {
  77.                 result += "D";
  78.             }
  79.             else if(p_cekor == 1) {
  80.                 result += "U";
  81.             }
  82.             else if(p_cekor == 2) {
  83.                 result += "R";
  84.             }
  85.             else {
  86.                 result += "L";
  87.             }
  88.             E = make_pair(E.first - di[p_cekor], E.second - dj[p_cekor]);
  89.         }
  90.         reverse(result.begin(), result.end());
  91.         cout <<result.size() << endl <<  result << endl;
  92.     }
  93.     else {
  94.         cout << "NO" << endl;
  95.     }
  96.    
  97.     return 0;
  98.  
  99. }
  100.  
  101.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement