목록알고리즘 (266)
Dev.baelanche
1차원 배열에서 방문 이력을 기록하면서 이동하는 문제이다. 변수 D 를 음수로 쓰는것만 까먹지 않으면 된다. public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int f = sc.nextInt(); int s = sc.nextInt(); int g = sc.nextInt(); int u = sc.nextInt(); int d = sc.nextInt(); Queue queue = new LinkedList(); int a[] = new int[f+1]; boolean visited[] = new boolean[f+1]; int mx[] = {u, -d}; boolean success..
여타 BFS 문제처럼 1에서 확장하고 -1은 벽으로 취급하여 푼다. 안익은 토마토(0)이 없을때의 카운트를 출력해준다. public class Main { static int m; static int n; static int a[][]; public static void main(String[] args) { Scanner sc = new Scanner(System.in); m = sc.nextInt(); n = sc.nextInt(); a = new int[n][m]; for(int i=0; i
2차원 배열에서 BFS 를 순회하는데 벽을 한 번 부술 수 있다. 방문 정보 배열을 2층으로 구성하여 벽을 부수고 지나갔을 때의 정보와 벽을 안부쉈을때의 정보를 따로 기록한다. 큐에도 벽 부수기에 대한 정보를 담아 한번 부수면 더이상 부술수 없게 한다. public class Main { static int n; static int m; static int a[][]; public static void main(String[] args) { Scanner sc = new Scanner(System.in); n = sc.nextInt(); m = sc.nextInt(); a = new int[n][m]; for(int i=0; i
이 문제와 로직이 같은 문제이다. public class Main { static int r; static int c; static char a[][]; public static void main(String[] args) { Scanner sc = new Scanner(System.in); r = sc.nextInt(); c = sc.nextInt(); a = new char[r][c]; for(int i=0; i
빠른 시간이므로 BFS 로 접근해야한다. 시간이 지날때마다 사람의 이동, 불의 이동이 이루어지므로 큐를 따로 만들어 사용한다. 처음에는 사람 이동 -> 불 이동 순으로 구현했었는데 예제는 모두 통과하는데도 틀리다고 나왔다. 문제에 불이 옮겨옴과 동시에 이동할 수 있다는 구문을 보고 불 이동 -> 사람 이동 으로 순서를 바꾸었더니 통과했다. 불이 먼저 이동해서 사람 위치를 차지하면 사람이 안움직일줄 알았는데 이미 큐에 담겨있어서 움직일 수 있었다. # # . # # # # . # # 사람 사람 . 불 불 사람 # # # 불 사람 # # # 불 왜 틀렸는지에 대한 예제를 생각해냈다. 사람, 불은 빨간 위치에서 시작하고 현재 3칸씩 이동한 상황이다. 사람 -> 불 순으로 이동하면 사람이 (3, 3) 으로 이동..
최단 시간을 구해야하므로 BFS 로 접근한다. 지나갈 수 있는 길을 탐색하면 되는데 배열이 3차원이라는 데에 주의해야 한다. S . . . . # # # # # # # # # # . # # # . # # # # # # # # # # . # # . . # # . # # # . # # # # # # . # # # . . . # # # # E 예제로 풀이해보자. 왼쪽부터 1, 2, 3층이다. S . . . . # # # # # # # # # # . # # # . # # # # # # # # # # . # # . . # # . # # # . # # # # # # . # # # . . . # # # # E 한칸 이동했을때이다. 가까운 동서남북상하로 이동했다. S . . . . # # # # # # # # # # ..
dp 배열에 사탕의 최대값을 저장하면서 풀면된다. 1 2 3 4 0 0 0 5 9 8 7 6 오른쪽, 아래, 대각선으로 이동하므로 가장자리의 줄은 더해서 채워준다. 1 3 6 10 1 0 0 5 10 8 7 6 나머지 칸들은 [i-1][j-1], [i-1][j], [i][j-1] 중 최대값을 저장한다. 1 3 6 10 1 3 6 15 10 18 25 31 public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); int m = sc.nextInt(); int a[][] = new int[n][m]; int dp[][] = new int[n][m]; f..
BFS 로 인접노드 탐색을 하는 문제다. 나이트는 날일 자로 이동하기 때문에 이 부분만 기억하고 풀면된다. public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int t = sc.nextInt(); int mx[] = {-1, 1, 2, 2, 1, -1, -2, -2}; int my[] = {2, 2, 1, -1, -2, -2, -1, 1}; while(t-->0) { int l = sc.nextInt(); boolean visited[][] = new boolean[l][l]; int jump[][] = new int[l][l]; Queue q = new LinkedList(); ..