상세 컨텐츠

본문 제목

[BJ] 4179 : 불!

💯ProblemSolving/문제 풀이

by :Eundms 2024. 4. 7. 10:46

본문

       문제 요약        

- 문제

 

 

- 입출력

 

         아이디어        

움직이는 대상이 불, 지훈이 2개였다

불은 시간에 따라 (지훈이가 있던 말던) 상하좌우로 퍼지기 때문에

해당 지역이 불붙는 시간을 미리 계산해두고

지훈이가 불이 (아직) 붙지 않은 위치로 움직여서 탈출할 수 있는지 확인하면 된다 

 

         소스코드        

 

 

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayDeque;
import java.util.Queue;
import java.util.StringTokenizer;

class Main {
	static int R,C;
	static char[][] box;
	static Position start;
	static Queue<Item> fire;
	public static void main(String[] args)throws Exception{
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st = new StringTokenizer(br.readLine());
		R = Integer.parseInt(st.nextToken());
		C = Integer.parseInt(st.nextToken());

		int[][] fireTime = new int[R][C];
		
		box = new char[R][C];
		fire = new ArrayDeque<>();
		for(int r = 0; r < R; r++) {
			String str = br.readLine();
			for(int c = 0; c < C; c++) {
				box[r][c] = str.charAt(c);
				if(box[r][c] == 'J') {
					start = new Position(r,c);	
					box[r][c] = '.';
				} else if(box[r][c] == 'F') {
					fire.add(new Item(0,new Position(r,c)));
				} else if(box[r][c] == 'W') {
					fireTime[r][c] = -1;
				} else if(box[r][c] == '#') {
					fireTime[r][c] = -1;
				}
			}
		}
		
		boolean[][] visited = new boolean[R][C];
		while(!fire.isEmpty()) {
			Item now = fire.poll();
			if(visited[now.position.x][now.position.y])continue;
			visited[now.position.x][now.position.y] = true;
			fireTime[now.position.x][now.position.y] = now.time;
			for(int w = 0; w < 4; w++) {
				int nx = now.position.x + way[w][0];
				int ny = now.position.y + way[w][1];
				if(nx < 0 || nx >= R || ny < 0 || ny >= C)continue;
				if(visited[nx][ny])continue;
				if(box[nx][ny] == '.') {
					fire.add(new Item (now.time + 1, new Position(nx,ny)));	
				}
			}
		}
		
		Queue<Item> queue = new ArrayDeque<>();
		visited = new boolean[R][C];
		queue.add(new Item(0,start));
		while(!queue.isEmpty()) {
			Item now = queue.poll();
			if(visited[now.position.x][now.position.y])continue;
			visited[now.position.x][now.position.y] = true;
			
			for(int w = 0; w < 4 ; w++) {
				int nx = now.position.x + way[w][0];
				int ny = now.position.y + way[w][1];
				if(nx<0 || nx>=R || ny<0 || ny>=C) {System.out.println(now.time+1);return;}
				if(visited[nx][ny])continue;
				if(box[nx][ny]=='.' && (fireTime[nx][ny] > now.time + 1 || fireTime[nx][ny] == 0)) {
					queue.add(new Item(now.time+1, new Position(nx,ny)));
				}
			}
		}
		System.out.println("IMPOSSIBLE");
	}
	static int[][] way = {{-1,0},{1,0},{0,1},{0,-1}};
	static class Position {
		int x, y;
		Position(int x, int y){
			this.x = x;
			this.y = y;
		}
	}
	static class Item {
		int time;
		Position position;
		Item(int time, Position position){
			this.time = time;
			this.position = position;
		}	
	}
}
728x90

'💯ProblemSolving > 문제 풀이' 카테고리의 다른 글

[BJ] 17836 : 공주님을 구해라!  (0) 2024.04.10
[BJ] 10655 : 마라톤1  (0) 2024.04.07
[BJ] 9466 : 텀 프로젝트  (0) 2024.03.01
[BJ] 12865 : 평범한 배낭  (0) 2024.03.01
[SWEA] 사탕 가방  (0) 2024.02.19

관련글 더보기

댓글 영역