알고리즘/C++

[백준] 6198번 옥상 정원 꾸미기

엑츄얼리 2021. 3. 8. 18:23

www.acmicpc.net/problem/6198

 

6198번: 옥상 정원 꾸미기

문제 도시에는 N개의 빌딩이 있다. 빌딩 관리인들은 매우 성실 하기 때문에, 다른 빌딩의 옥상 정원을 벤치마킹 하고 싶어한다. i번째 빌딩의 키가 hi이고, 모든 빌딩은 일렬로 서 있고 오른쪽으

www.acmicpc.net

꼭 기억해놓으면 좋을 것 같은 방식이다. 스택에서 말고도 여기저기 많이 쓰여서 몇번 찾아서 다시 봤는데도 암기가 잘 안되서 그냥 외우겠다는 마인드로 정리한다.

 

아이디어는 다음과 같다. (스택함수가 아닌 배열을 스택식으로 사용했다.)

여러개의 건물이 있을 때 N번째의 건물을 볼 수 있는 것은 N번째 이전의 건물 중 N번째보다 높은 건물만 N번째를 볼 수 있다. (같아도 안됨)

따라서 N번째 이전에 존재하는 N번째 건물보다 높이가 같거나 낮은 건물은 순서대로 제거한다. (N번째 건물로 인해 뒤에 건물을 볼 수 없으므로 결과값에 영향을 미칠 수 없다.)

앞의 결과물로 존재하는 건물의 배열(스택)의 높이는 내림차순으로 존재하게 된다.

sum의 값에 N번째 이전의 건물의 개수를 더한다.

N + 1번째 건물에 대해 위의 과정을 반복한다.

 

N : 건물의 개수

pos : 새로운 건물의 높이를 입력 받을 때 까지 배열에 존재하는 건물의 개수(=위치)

 

//6198
#include <iostream>

using namespace std;

const int MX = 80005;
int dat[MX];
int pos = 1;

int main(void)
{
	ios::sync_with_stdio(false); cin.tie(NULL);
	int N, cnt = 0;
	long long sum = 0;
	int buf;

	cin >> N;

	for (int i = 1; i <= N; i++)
	{
		cin >> buf;

		while (pos != 1 && dat[pos - 1] <= buf)
			pos--;

		sum += (long long)(pos - 1);
		dat[pos] = buf;
		pos++;
	}
	cout << sum;

	return 0;
}