Coding Test

[Java / Kotlin] 99 클럽 코딩 테스트 스터디 비기너 13일차 - 숫자 카드

SeungYong.Lee 2024. 8. 3. 18:55
반응형

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

 

[문제]

숫자 카드는 정수 하나가 적혀 있는 카드이다. 상근이는 숫자 카드 N개를 가지고 있다. 정수 M개가 주어졌을 때, 이 수가 적혀있는 숫자 카드를 상근이가 가지고 있는지 아닌지를 구하는 프로그램을 작성하시오.

 

첫째 줄에 상근이가 가지고 있는 숫자 카드의 개수 N(1 ≤ N ≤ 500,000)이 주어진다. 둘째 줄에는 숫자 카드에 적혀있는 정수가 주어진다. 숫자 카드에 적혀있는 수는 -10,000,000보다 크거나 같고, 10,000,000보다 작거나 같다. 두 숫자 카드에 같은 수가 적혀있는 경우는 없다.

셋째 줄에는 M(1 ≤ M ≤ 500,000)이 주어진다. 넷째 줄에는 상근이가 가지고 있는 숫자 카드인지 아닌지를 구해야 할 M개의 정수가 주어지며, 이 수는 공백으로 구분되어 있다. 이 수도 -10,000,000보다 크거나 같고, 10,000,000보다 작거나 같다

 

첫째 줄에 입력으로 주어진 M개의 수에 대해서, 각 수가 적힌 숫자 카드를 상근이가 가지고 있으면 1을, 아니면 0을 공백으로 구분해 출력한다.

 

[입출력 예]

 

[풀이]

두 번째로 주어진 Integer 리스트의 각 요소가 첫 번째로 주어진 Integer 요소에 포함되어 있다면 1, 아니라면 0으로 치환해주면 되는 문제입니다.

 

자바 코드입니다.

public static void main(String[] args) throws IOException {
    BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));

    int n = Integer.parseInt(reader.readLine());
    Set<Integer> cardSet = new HashSet<>();
    String[] cards = reader.readLine().split(" ");
    for (String card : cards) {
        cardSet.add(Integer.parseInt(card));
    }

    int m = Integer.parseInt(reader.readLine());
    String[] checkCards = reader.readLine().split(" ");
    StringBuilder result = new StringBuilder();
    for (String card : checkCards) {
        int num = Integer.parseInt(card);
        if (cardSet.contains(num)) {
            result.append("1 ");
        } else {
            result.append("0 ");
        }
    }
    System.out.println(result);
}

checkCards 리스트를 순회하면서 상근이가 가진 Set에 포함된 요소인지 검사하여 1 또는 0을 StringBuilder에 append하여 답을 출력합니다.

 

코틀린 코드입니다.

fun main() = with(BufferedReader(InputStreamReader(System.`in`))) {
    val n = readln().toInt()
    val cardSet = readln().split(" ").map { it.toInt() }.toMutableSet()
    val m = readln().toInt()

    readln().split(" ").map { it.toInt() }.forEach {
        if (!cardSet.add(it)) print("1 ") else print("0 ")
    }
}

더 간단해집니다. 첫 번째 목록은 입력받은 문자열을 공백을 기준으로 구분하여 리스트로 만든 뒤, 각 요소를 map 함수를 통해 Int형으로 변환하고 Set으로 정리해 줍니다.

그리고 두 번째 배열은 리스트로 생성한 뒤, 바로 조건에 따라 "1 " 또는 "0 "을 출력합니다.

반응형