문제
N개의 정수 A[1], A[2], …, A[N]이 주어져 있을 때, 이 안에 X라는 정수가 존재하는지 알아내는 프로그램을 작성하시오.
입력
첫째 줄에 자연수 N(1 ≤ N ≤ 100,000)이 주어진다. 다음 줄에는 N개의 정수 A[1], A[2], …, A[N]이 주어진다. 다음 줄에는 M(1 ≤ M ≤ 100,000)이 주어진다. 다음 줄에는 M개의 수들이 주어지는데, 이 수들이 A안에 존재하는지 알아내면 된다. 모든 정수의 범위는 -231 보다 크거나 같고 231보다 작다.
출력
M개의 줄에 답을 출력한다. 존재하면 1을, 존재하지 않으면 0을 출력한다.
문제 설계
이분탐색을 사용하여 숫자가 배열에 존재하는지 알아낸다.
풀이 과정
코드
#include <iostream>
#include <algorithm>
using namespace std;
int arr[100001];
bool search(int left, int right, int key)
{
while(left <= right)
{
int mid = (left+right)/2;
if(arr[mid] == key) // 값을 찾은 경우
return true;
else if(key < arr[mid]) // 찾아야 하는 값이 중간보다 작은 경우
right = mid-1;
else // 찾아야 하는 값이 중간보다 큰 경우
left = mid+1;
}
return false; // 탐색 실패
}
int main()
{
int n, m, find;
scanf("%d", &n);
for(int i=0; i<n; i++)
{
scanf("%d", &arr[i]);
}
sort(arr, arr+n);
scanf("%d", &m);
for(int i=0; i<m; i++)
{
scanf("%d", &find);
if(search(0, n-1, find))
{
printf("1\n");
}
else printf("0\n");
}
return 0;
}
결과
while(left<right)로 해서 틀렸었다.