[C++] 백준(BOJ) - 3273 : 두 수의 합
인프런에 있는 큰돌님의 강의 10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트를 듣고 정리한 필기입니다.
문제
n개의 서로 다른 양의 정수 a1, a2, …, an으로 이루어진 수열이 있다. ai의 값은 1보다 크거나 같고, 1000000보다 작거나 같은 자연수이다. 자연수 x가 주어졌을 때, ai + aj = x (1 ≤ i < j ≤ n)을 만족하는 (ai, aj)쌍의 수를 구하는 프로그램을 작성하시오.
입력
첫째 줄에 수열의 크기 n이 주어진다. 다음 줄에는 수열에 포함되는 수가 주어진다. 셋째 줄에는 x가 주어진다. (1 ≤ n ≤ 100000, 1 ≤ x ≤ 2000000)
출력
문제의 조건을 만족하는 쌍의 개수를 출력한다.
알고리즘
- 정렬
- 투포인터 알고리즘
풀이
- 문제의 조건을 만족하는 쌍의 개수만이 궁금 -> 정렬 가능
- 두 개의 쌍 = 투포인터, 스택 항상 생각하기
코드
// BOJ-3273 : 두 수의 합
#include <bits/stdc++.h>
using namespace std;
int n, a[100004], res, x;
int main()
{
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cin >> n;
for (int i = 0; i < n; i++)
{
cin >> a[i];
}
cin >> x;
sort(a, a + n);
int p1 = 0, p2 = n - 1;
while (p1 < p2)
{
if (a[p1] + a[p2] < x) p1++;
else if (a[p1] + a[p2] == x)
{
res++;
p1++;
}
else p2--;
}
cout << res << '\n';
return 0;
}
평가
- 두 개의 쌍 = 투포인터 알고리즘, 스택
- 간단한 예시를 들어가며 생각하기