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 "을 출력합니다.