답안 #448519

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
448519 2021-07-30T11:05:06 Z mychecksedad Awesome Arrowland Adventure (eJOI19_adventure) C++17
34 / 100
4 ms 6348 KB
#include <bits/stdc++.h>
using namespace std;
typedef long long int ll;
const int N = 505;
#define pii pair<int,int>
#define pb push_back
struct Edge{
    int x, y, w;
};

int n, m, dist[N][N];
char c;
vector<Edge> g[N][N];
bool vis[N][N];


int main(){
    cin.tie(0); ios::sync_with_stdio(0);
    cin >> n >> m;
    int arr[4][2]={{-1, 0}, {0, 1}, {1, 0}, {0, -1}};
    for(int i = 0; i <= n+2; i++) for(int j = 0; j <= m+2; j++) {dist[i][j] = 1e9; vis[i][j] = 0;}
    Edge e;
    for(int i = 1; i <= n; i++){
        for(int j = 1; j <= m; j++){
            cin >> c;
            int co;
            if(c == 'N'){
                co = 0;
                for(int k = 0; k < 4; k++){
                    e.x = i + arr[(k+co)%4][0];
                    e.y = j + arr[(k+co)%4][1];
                    e.w = k;
                    g[i][j].pb(e);
                }
            }else if(c == 'E'){
                co=1;
                for(int k = 0; k < 4; k++){
                    e.x = i + arr[(k+co)%4][0];
                    e.y = j + arr[(k+co)%4][1];
                    e.w = k;
                    g[i][j].pb(e);
                }
            }else if(c == 'S'){
                co=2;
                for(int k = 0; k < 4; k++){
                    e.x = i + arr[(k+co)%4][0];
                    e.y = j + arr[(k+co)%4][1];
                    e.w = k;
                    g[i][j].pb(e);
                }
            }else if(c == 'W'){
                co=3;
                for(int k = 0; k < 4; k++){
                    e.x = i + arr[(k+co)%4][0];
                    e.y = j + arr[(k+co)%4][1];
                    e.w = k;
                    g[i][j].pb(e);
                }
            }
        }   
    }
    dist[1][1] = 0;
    priority_queue<pair<int, pii>> q;
    q.push({0, {1, 1}});

    while(!q.empty()){
        int x = q.top().second.first, y = q.top().second.second;
        q.pop();
        if(vis[x][y]) continue;
        vis[x][y] = 1;
        for(Edge u: g[x][y]){
            if(!vis[u.x][u.y] && dist[x][y] + u.w < dist[u.x][u.y]){
                dist[u.x][u.y] = dist[x][y] + u.w;
                q.push({-u.w, {u.x, u.y}});
            }
        }
    }
    cout << (!vis[n][m] ? -1 : dist[n][m]);
    // string s="WSEN";
    // srand(time(0));
    // for(int i = 0; i < 5; i++){
        
    //     cout << 2 << ' ' << 10 << '\n';
    //     for(int j = 0; j < 2; j++){
    //         for(int k=0;k<3;k++){
    //             int r = rand()%40;
    //             if(r >= 37) cout << 'X';
    //             else cout << s[r/10];
    //         }
    //         cout << '\n';
    //     }
    // }

    return 0;
}
# 결과 실행 시간 메모리 Grader output
1 Correct 4 ms 6220 KB Output is correct
2 Correct 4 ms 6220 KB Output is correct
3 Correct 4 ms 6348 KB Output is correct
4 Correct 4 ms 6348 KB Output is correct
5 Correct 4 ms 6252 KB Output is correct
6 Correct 4 ms 6348 KB Output is correct
7 Correct 4 ms 6220 KB Output is correct
8 Correct 4 ms 6220 KB Output is correct
9 Correct 4 ms 6348 KB Output is correct
10 Correct 4 ms 6220 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 4 ms 6220 KB Output is correct
2 Correct 4 ms 6220 KB Output is correct
3 Correct 4 ms 6348 KB Output is correct
4 Correct 4 ms 6348 KB Output is correct
5 Correct 4 ms 6252 KB Output is correct
6 Correct 4 ms 6348 KB Output is correct
7 Correct 4 ms 6220 KB Output is correct
8 Correct 4 ms 6220 KB Output is correct
9 Correct 4 ms 6348 KB Output is correct
10 Correct 4 ms 6220 KB Output is correct
11 Correct 4 ms 6220 KB Output is correct
12 Correct 4 ms 6220 KB Output is correct
13 Correct 4 ms 6348 KB Output is correct
14 Correct 4 ms 6220 KB Output is correct
15 Correct 4 ms 6220 KB Output is correct
16 Correct 4 ms 6348 KB Output is correct
17 Correct 4 ms 6328 KB Output is correct
18 Correct 4 ms 6232 KB Output is correct
19 Correct 4 ms 6220 KB Output is correct
20 Correct 4 ms 6264 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 4 ms 6228 KB Output is correct
2 Correct 4 ms 6220 KB Output is correct
3 Correct 4 ms 6220 KB Output is correct
4 Correct 4 ms 6220 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 4 ms 6348 KB Output is correct
2 Incorrect 4 ms 6220 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 4 ms 6220 KB Output is correct
2 Correct 4 ms 6220 KB Output is correct
3 Correct 4 ms 6348 KB Output is correct
4 Correct 4 ms 6348 KB Output is correct
5 Correct 4 ms 6252 KB Output is correct
6 Correct 4 ms 6348 KB Output is correct
7 Correct 4 ms 6220 KB Output is correct
8 Correct 4 ms 6220 KB Output is correct
9 Correct 4 ms 6348 KB Output is correct
10 Correct 4 ms 6220 KB Output is correct
11 Correct 4 ms 6220 KB Output is correct
12 Correct 4 ms 6220 KB Output is correct
13 Correct 4 ms 6348 KB Output is correct
14 Correct 4 ms 6220 KB Output is correct
15 Correct 4 ms 6220 KB Output is correct
16 Correct 4 ms 6348 KB Output is correct
17 Correct 4 ms 6328 KB Output is correct
18 Correct 4 ms 6232 KB Output is correct
19 Correct 4 ms 6220 KB Output is correct
20 Correct 4 ms 6264 KB Output is correct
21 Correct 4 ms 6228 KB Output is correct
22 Correct 4 ms 6220 KB Output is correct
23 Correct 4 ms 6220 KB Output is correct
24 Correct 4 ms 6220 KB Output is correct
25 Correct 4 ms 6348 KB Output is correct
26 Incorrect 4 ms 6220 KB Output isn't correct
27 Halted 0 ms 0 KB -