문제 링크
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=' ')
- 입력 최적화
- sys.stdin.readline()은 input()보다 훨씬 빠르다.
- 입력 데이터가 많을 때 시간초과를 방지하기 위해 사용한다.
- sys.stdin.readline()은 input()보다 훨씬 빠르다.
- import sys n = int(sys.stdin.readline())
- 기준 수열 입력 (narr)
- set()으로 저장하는 이유:
- in 연산의 시간 복잡도가 평균 O(1) .
- set()으로 저장하는 이유:
- narr = set(map(int, sys.stdin.readline().split()))
- 찾을 숫자 목록 입력 (marr)
- marr는 리스트로 저장
- 순차적으로 탐색하면서 출력할 것이기 때문
- marr는 리스트로 저장
- m = int(sys.stdin.readline()) marr = list(map(int, sys.stdin.readline().split()))
- 존재 여부 검사
- if x in narr:
- x가 narr에 있으면 1, 없으면 0 출력
- end=' '를 이용해 공백으로 구분된 한 줄 출력
- if x in narr:
- for x in marr: if x in narr: print(1, end=' ') else: print(0, end=' ')
'백준' 카테고리의 다른 글
| [백준] 1620 : 나는야 포켓몬 마스터 이다솜 (Python/파이썬) (0) | 2025.11.02 |
|---|---|
| [백준] 14425 : 문자열 집합 (Python/파이썬) (0) | 2025.11.02 |
| [백준] 18870 : 좌표 압축 (Python/파이썬) (1) | 2025.10.31 |
| [백준] 10814 : 나이순 정렬 (Python/파이썬) (0) | 2025.10.31 |
| [백준] 1181 : 단어 정렬 (Python/파이썬) (0) | 2025.10.31 |