백준

[백준] 10815 : 숫자카드 (Python/파이썬)

sson-coding 2025. 11. 2. 23:49

문제 링크

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

문제

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

- 시간 제한 : 2초
- 메모리 제한 : 256 MB

입력

첫째 줄에 상근이가 가지고 있는 숫자 카드의 개수 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을 공백으로 구분해 출력한다.

예제

입력

5
6 3 2 10 -10
8
10 9 -5 2 3 4 5 -10

출력

1 0 0 1 1 0 0 1

정답 및 풀이

import sys

n = int(sys.stdin.readline())
narr = set(map(int, sys.stdin.readline().split()))
m = int(sys.stdin.readline())
marr = list(map(int, sys.stdin.readline().split()))

for x in marr:
    if x in narr:
        print(1, end=' ')
    else:
        print(0, end=' ')

  1. 입력 최적화
    • sys.stdin.readline()은 input()보다 훨씬 빠르다.
      • 입력 데이터가 많을 때 시간초과를 방지하기 위해 사용한다.
  2. import sys n = int(sys.stdin.readline())
  3. 기준 수열 입력 (narr)
    • set()으로 저장하는 이유:
      • in 연산의 시간 복잡도가 평균 O(1) .
  4. narr = set(map(int, sys.stdin.readline().split()))
  5. 찾을 숫자 목록 입력 (marr)
    • marr는 리스트로 저장
      • 순차적으로 탐색하면서 출력할 것이기 때문
  6. m = int(sys.stdin.readline()) marr = list(map(int, sys.stdin.readline().split()))
  7. 존재 여부 검사
    • if x in narr:
      • x가 narr에 있으면 1, 없으면 0 출력
    • end=' '를 이용해 공백으로 구분된 한 줄 출력
  8. for x in marr: if x in narr: print(1, end=' ') else: print(0, end=' ')