알고리즘/백준
17298번 오큰수
글을 쓰는 개발자
2020. 12. 1. 20:40
반응형
문제:www.acmicpc.net/problem/17298
17298번: 오큰수
첫째 줄에 수열 A의 크기 N (1 ≤ N ≤ 1,000,000)이 주어진다. 둘째에 수열 A의 원소 A1, A2, ..., AN (1 ≤ Ai ≤ 1,000,000)이 주어진다.
www.acmicpc.net
이 문제에서 막힌 부분은 시간초과 였다. 쇠막대기 문제와 비슷한 이유였다. 최악의 경우 시간복잡도 문제가 N^2이 나오기 때문이다. 아래의 코드는 시간초과로 틀렸던 코드이다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
#include<iostream>
#include<vector>
#include<cmath>
#include<stack>
#include<deque>
using namespace std;
int main()
{
int vol;
cin >> vol;
deque<int> val;
deque<int> container;
int tmp;
for (int i = 0; i < vol; i++)
{
cin >> tmp;
val.push_back(tmp);
}
for (int i = 0; i < vol; i++)
{
int look = val.front();
val.pop_front();
while (val.size()>0&&look >= val.front())
{
container.push_back(val.front());
val.pop_front();
}
if (val.size() != 0)
{
cout << val.front() << " ";
}
else
{
cout << -1 << " ";
}
auto it = val.insert(val.begin(), container.begin(), container.end());
container = deque<int>();
}
}
|
cs |
이 문제의 접근법은 Stack의 활용에 있다. 접근 방법은 처음 원소는 비교할 대상이 없으니 우선 스택에 push하고 다음 차례부터는 스택의 top의 위치에 해당하는 값이 지금 차례의 값보다 처음으로 작을때 그 값을 저장하고 확인된 스택 값을 pop하는 형식이다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
#include <iostream>
#include <cstring>
#include <algorithm>
#include <vector>
#include <stack>
using namespace std;
int main(int argc, char *argv[])
{
int n;
int num;
vector<int> v;
stack<int> s;
scanf("%d", &n);
for (int i = 0; i < n; i++) {
scanf("%d", &num);
v.push_back(num);
}
vector<int> ans(v.size(), -1);
for (int i = 0; i < v.size(); i++) {
while (!s.empty() && v[s.top()] < v[i]) {
ans[s.top()] = v[i];
s.pop();
}
s.push(i);
}
for (int x : ans) {
cout << x << " ";
}
return 0;
}
|
cs |
위의 코드는 다음 블로그에서 참고했다.
[C++] 백준 17298번 오큰수
스택 문제입니다. A의 수열이 있을 때 Ai의 오른쪽에는 경우 Ai+1 ~ Ai+n가 있습니다. Ai+1 ~ Ai+n에서 Ai와 가장 가까운 Ai보다 큰 수를 구하면 됩니다. 없을 시에 -1을 출력합니다. vecot v에는 입력 받은
j3sung.tistory.com
반응형