https://www.acmicpc.net/problem/2776
문제 해석
간단히 수첩 2에 적혀 놓은 정수가 수첩 1에 적혀 있는지 찾는 문제이다.
코드
input = __import__('sys').stdin.readline
t = int(input())
for k in range(t):
n = int(input())
arr = list(map(int, input().split()))
m = int(input())
isIn = list(map(int, input().split()))
arr = sorted(arr)
for i in isIn:
s = 0
e = n - 1
flag = True
while s <= e:
mid = (s + e) // 2
if arr[mid] == i:
print(1)
flag = False
break
elif arr[mid] < i:
s = mid + 1
else:
e = mid - 1
if flag: print(0)
문제 풀이
들어가는 수의 범위는 int형의 범위이고, 정수의 개수는 1,000,000 이므로 일반적인 탐색 방법으로는 시간초과가 난다.따라서 이분탐색을 통해 문제를 풀어주면 된다.수첩2의 적힌 배열들이 수첩1에 적혀 있는지 이분 탐색을 통해 확인하고, 없다면 flag == True로 0을 출력하고, 있다면 1을 출력하면 되는 간단한 문제이다.
이 문제에는 T의 테스트 케이스를 받아서 1번 이상 진행한다. 문제를 잘 보고 풀어야 할 것 같다.
원문
https://ddingmin00.tistory.com/28
'Koala - 6기 > 코딩테스트 준비 스터디' 카테고리의 다른 글
[백준/C++] 2346번 풍선 터뜨리기 (0) | 2022.04.28 |
---|---|
[백준 / python] 2535번: 아시아 정보올림피아드 (0) | 2022.04.04 |
[BOJ / Python] 2805 - 나무 자르기 (0) | 2022.04.03 |
[백준/C++] 2110번 공유기 설치 (0) | 2022.03.30 |
[BOJ/python] 14503번 로봇 청소기 (0) | 2022.03.27 |