OJ

[BOJ] 1107 리모컨 (JAVA)

P3PP4 2023. 8. 5. 10:00

https://www.acmicpc.net/problem/1107

 

1107번: 리모컨

첫째 줄에 수빈이가 이동하려고 하는 채널 N (0 ≤ N ≤ 500,000)이 주어진다.  둘째 줄에는 고장난 버튼의 개수 M (0 ≤ M ≤ 10)이 주어진다. 고장난 버튼이 있는 경우에는 셋째 줄에는 고장난 버튼

www.acmicpc.net

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.LinkedList;
import java.util.Queue;
import java.util.StringTokenizer;

public class Main {
	
    public static void main(String[] args) throws Exception {

        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int N = Integer.parseInt(br.readLine());
        int M = Integer.parseInt(br.readLine());
        boolean[] NA = new boolean[10];
        boolean[] num = new boolean[1000001];
        if (M != 0) {
            StringTokenizer st = new StringTokenizer(br.readLine(), " ");
            for (int i = 0; i < M; i++) {
                NA[Integer.parseInt(st.nextToken())] = true;
            }
        }

        int[] visited = new int[1000001];
        Queue<Integer> q = new LinkedList<>();
        visited[100] = 1;
        q.offer(100);

        while (!q.isEmpty()) {
            int i = q.poll();

            if (i == N) {
                System.out.print(visited[i] - 1);
                return;
            }

            if (0 <= i - 1 && visited[i - 1] == 0) {
                visited[i - 1] = visited[i] + 1;
                q.offer(i - 1);
            }
            if (i + 1 < 1000001 && visited[i + 1] == 0) {
                visited[i + 1] = visited[i] + 1;
                q.offer(i + 1);
            }

            for (int j = 0; j < 10; j++) {
                if (NA[j]) continue;

                if (visited[j] == 0) {
                    num[j] = true;
                    visited[j] = visited[i] + 1;
                    q.offer(j);
                }

                int k = i * 10 + j;
                if (num[i] && k < 1000001 && !num[k]) {
                    num[k] = true;
                    visited[k] = visited[i] + 1;
                    q.offer(k);
                }
            }

        }

    }
	
}