[C++] 백준 1920. 수 찾기

멋진감자·2025년 1월 10일
1

알고리즘

목록 보기
65/104
post-thumbnail

🌽 문제

🥔 풀이

.find()로 풀었다가 시간초과(당연)나서 이진탐색으로 풀었다.
복습이 되어 좋았다.!

🥬 코드

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;

int n, m, tmp;
vector<int> v;

int binarySearch() {
	int st = 0;
	int en = n - 1;
	int mid;

	while (st <= en) {
		mid = (st + en) / 2;
		if (v[mid] == tmp) return 1;
		if (v[mid] < tmp) st = mid + 1;
		else if (v[mid] > tmp) en = mid - 1;
	}
	return 0;
}

int main() {
	ios::sync_with_stdio(0);
	cin.tie(0);
	cin >> n;
	for (int i = 0; i < n; i++) {
		cin >> tmp;
		v.push_back(tmp);
	}
	sort(v.begin(), v.end());
	cin >> m;
	for (int i = 0; i < m; i++) {
		cin >> tmp;
		cout << binarySearch() << "\n";
	}
	return 0;
}

🥜 채점

시간초과는 ios::sync_with_stdio(0); cin.tie(0);으로 해결

profile
난멋져

0개의 댓글

관련 채용 정보