[BOJ] 1107 리모컨

알파·2022년 7월 22일
0
  1. 0부터 999999까지 for문을 돌린다.
  2. String값으로 바꿔 고장난 버튼이 포함되어 있을 경우 continue.
  3. 아닐 경우에는 length값 + N과의 절대값을 구해 min 체크해준다.
  4. 100-N과 비교하여 더 작은 값이 정답이 된다.
    int값을 String으로 바꾸고 싶을 경우 str.valueOf(i) 사용하기
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.StringTokenizer;

public class Main {

    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int N = Integer.parseInt(br.readLine());
        int M = Integer.parseInt(br.readLine());
        ArrayList<Integer> button = new ArrayList<>();
        if (M != 0) {
            StringTokenizer st = new StringTokenizer(br.readLine());
            for (int i = 0; i < M; i++) {
                button.add(Integer.parseInt(st.nextToken()));
            }
        }
        int min = Integer.MAX_VALUE;
        int cnt = 0;
        for (int i = 0; i <= 999999; i++) {
            String str = String.valueOf(i);
            boolean check = true;
            for (int j = 0; j < str.length(); j++) {
                if (button.contains(str.charAt(j) - '0')) {
                    check = false;
                    break;
                }
            }
            if (!check) {
                continue;
            }
            cnt = str.length() + Math.abs(i - N);
            if (cnt < min) {
                min = cnt;
            }
        }
        System.out.println(Math.min(Math.abs(100 - N), min));
    }
}
profile
I am what I repeatedly do

0개의 댓글