알고리즘 문제/백준

[백준 - Java] 11967번 : 불켜기

건복치 2021. 3. 1. 06:47
반응형

문제

www.acmicpc.net/problem/11967

 

11967번: 불켜기

(1, 1)방에 있는 스위치로 (1, 2)방과 (1, 3)방의 불을 켤 수 있다. 그리고 (1, 3)으로 걸어가서 (2, 1)방의 불을 켤 수 있다. (2, 1)방에서는 다시 (2, 2)방의 불을 켤 수 있다. (2, 3)방은 어두워서 갈 수 없으

www.acmicpc.net

설명

data-make.tistory.com/577

 

[BOJ] 11967.불켜기(완탐).java

#. Problem https://www.acmicpc.net/problem/11967 * The copyright in this matter is in BOJ #. Resolution Process   1. Read and understand problem 2. Redefine the problem + abstract 3. Create solu..

data-make.tistory.com

skygood95.tistory.com/91

 

백준 11967 <불켜기>

그래프 문제이긴 하지만 일반적인 BFS와 DFS랑은 다르게 생각이 필요한 문제였다. 이동을 할 때 불이 켜져 있으면 이동이 가능하기 때문에 이동을 할 수 있는 위치가 불이 켜져 있으면 계속 진행

skygood95.tistory.com

전체 코드

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;

public class Main {
	static int N;
	static ArrayList<Point>[][] switchs;
	static boolean[][] visited;
	static boolean[][] isLight;
	static boolean[][] isMove;
	static int cnt = 1;
	static int[] dx = {-1, 0, 1, 0};
	static int[] dy = {0, 1, 0, -1};

	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		N = sc.nextInt();
		int M = sc.nextInt();

		visited = new boolean[N][N];
		isLight = new boolean[N][N];
		isMove = new boolean[N][N];

		switchs = new ArrayList[N][N]; // x,y스위치로 켤 수 있는 a,b방에 대한 인접 리스트 만들기 
		for (int i = 0; i < N; i++) {
			for (int j = 0; j < N; j++) {
				switchs[i][j] = new ArrayList<>();
			}
		}

		for(int i = 0; i < M; i++) {
			int x = sc.nextInt()-1; // (0, 0) 시작을 위해 -1 
			int y = sc.nextInt()-1;
			int a = sc.nextInt()-1;
			int b = sc.nextInt()-1;

			switchs[x][y].add(new Point(a, b));
		}

		bfs();

		System.out.println(cnt);
	}

	public static void bfs() {
		Queue<Point> queue = new LinkedList<>();
		queue.add(new Point(0, 0));
		visited[0][0] = isLight[0][0] = true;

		while(!queue.isEmpty()) {
			int cx = queue.peek().x;
			int cy = queue.poll().y;

			// 현재 위치에서 이동할 수 있는 상하좌우 4방향 방 체크하기 
			for(int i = 0; i < 4; i++) {
				int nx = cx + dx[i];
				int ny = cy + dy[i];

				if(nx < 0 || ny < 0 || nx >= N || ny >= N) continue;

				isMove[nx][ny] = true;
			}

			// 현재 스위치가 켤 수 있는 모든 불들을 켜 봄 
			for(int i = 0; i < switchs[cx][cy].size(); i++) {
				Point p = switchs[cx][cy].get(i);

				if(!isLight[p.x][p.y]) { // 불이 꺼져있다면 불을 켬 
					isLight[p.x][p.y] = true;
					cnt++;
				}

				// 이동할 수 있는 방이라면 큐에 추가 
				if(isMove[p.x][p.y] && !visited[p.x][p.y]) {
					visited[p.x][p.y] = true;
					queue.add(new Point(p.x, p.y));
				}
			}

			// 본격적으로 현재 위치에서 이동할 수 있는 방으로 이동 
			for(int i = 0; i < 4; i++) {
				int nx = cx + dx[i];
				int ny = cy + dy[i];

				// 범위를 넘어가는 경우
				if(nx < 0 || ny < 0 || nx >= N || ny >= N) continue; 
				// 이미 방문한 방, 이동할 수 없는 방, 불이 꺼진 방의 경우 
				if(visited[nx][ny] || !isMove[nx][ny] || !isLight[nx][ny]) continue; 
				
				visited[nx][ny] = true;
				queue.add(new Point(nx, ny));
			}
		}
	}
}

class Point {
	int x;
	int y;

	Point(int x, int y) {
		this.x = x;
		this.y = y;
	}
}

GITHUB

 

KwonMinha/BOJ

Baekjoon Online Judge(Java) 문제풀이. Contribute to KwonMinha/BOJ development by creating an account on GitHub.

github.com

 

반응형