Untitled
unknown
plain_text
a year ago
2.9 kB
2
Indexable
Never
package OnLuyen; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.util.Scanner; public class MarioClimb { static int n, m, x_start, y_start, x_end, y_end, front, rear; static int[][] matrix = new int[55][55]; static int[] queueX = new int[55 * 55 * 2]; static int[] queueY = new int[55 * 55 * 2]; static int[][] visit; static int[] dx = { -1, 0, 1, 0 }; static int[] dy = { 0, 1, 0, -1 }; static void input(Scanner sc) { n = sc.nextInt(); m = sc.nextInt(); for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { matrix[i][j] = sc.nextInt(); if (matrix[i][j] == 2) { x_start = i; y_start = j; } if (matrix[i][j] == 3) { x_end = i; y_end = j; } } } } static int isOutOfCheck(int x, int y) { if (x < 0 || x >= n || y < 0 || y >= m) { return 1; } return 0; } static void push(int x, int y) { queueX[rear] = x; queueY[rear] = y; rear++; } static int find_h(int x, int y, int direct) { int h = 1; while (true) { if (isOutOfCheck(x + h * dx[direct], y) == 1 || matrix[x + h * dx[direct]][y] != 0) { break; } h++; } return h; } static void BFS() { int x, y, X, Y; while (front != rear) { x = queueX[front]; y = queueY[front]; for (int i = 0; i < 4; i++) { if (i == 0 || i == 2) { int h; h = find_h(x, y, i); X = h * dx[i] + x; Y = y + dy[i]; if (isOutOfCheck(X, Y) == 0) { if (visit[X][Y] == 0) { if (visit[x][y] < h + 1) { visit[X][Y] = h + 1; push(X, Y); } else { visit[X][Y] = visit[x][y]; push(X, Y); } } else { if (h + 1 > visit[x][y]) { if (h + 1 < visit[X][Y]) { visit[X][Y] = h + 1; push(X, Y); } } else { if (visit[x][y] < visit[X][Y]) { visit[X][Y] = visit[x][y]; push(X, Y); } } } } } else { X = x + dx[i]; Y = y + dy[i]; if (isOutOfCheck(X, Y) == 0 && matrix[X][Y] != 0) { if (visit[X][Y] == 0) { visit[X][Y] = visit[x][y]; push(X, Y); } else { if (visit[X][Y] > visit[x][y]) { visit[X][Y] = visit[x][y]; push(X, Y); } } } } } front++; } } static void solve(int tc) { front = rear = 0; visit = new int[n][m]; visit[x_start][y_start] = 1; push(x_start, y_start); BFS(); System.out.println(visit[x_end][y_end]-1); } public static void main(String[] args) throws FileNotFoundException { System.setIn(new FileInputStream("MarioClimb.txt")); Scanner sc = new Scanner(System.in); int T = sc.nextInt(); for (int i = 0; i < T; i++) { input(sc); solve(i + 1); } } }