60041 지그재그 Diamond V

시간 제한: 2초 (추가 시간 없음) 메모리 제한: 1024MB

문제

길이가 NN인 수열 A1,A2,,ANA_1, A_2, \ldots, A_N이 주어진다. 이 수열에는 11부터 NN까지의 정수가 모두 정확히 한 번씩 등장한다.

AA의 부분수열이란, 수열 AA에서 0개 이상의 원소를 제거해서 만든 수열을 뜻한다. 세 정수 x,y,zx, y, z (1x,y,zN1 \le x, y, z \le N, yzy \le z)가 주어졌을 때, 다음 조건들을 만족하는 AA 의 부분수열이 가질 수 있는 최대 길이를 f(x,y,z)f(x, y, z) 라 하자.

  1. 부분수열에 들어간 원소들은 원래 위치가 [y,z][y, z] 구간에 있어야 한다. 다시 말해, Ay,Ay+1,,AzA_y, A_{y + 1}, \ldots, A_z 의 원소들로만 부분수열을 구성할 수 있다.
  2. 부분수열의 모든 원소의 값은 xx 이하여야 한다.
  3. 부분수열은 지그재그 수열이어야 한다. 길이 KK 인 수열 S1,,SKS_1, \ldots, S_K지그재그 수열 이라는 것은, 각 ii (1iK21 \le i \le K-2)에 대해 Si<Si+1S_i < S_{i+1}이라면 Si+1>Si+2S_{i+1} > S_{i+2}가, Si>Si+1S_i > S_{i+1}이라면 Si+1<Si+2S_{i+1} < S_{i+2}가 성립하는 것으로 정의한다. 구체적으로, 길이가 2 이하인 수열은 모두 지그재그 수열이다.

길이가 0인 빈 수열은 위 세 조건을 모두 만족하기 때문에, 항상 f(x,y,z)0f(x, y, z) \geq 0 임에 유의하라.

1yzN1 \le y \le z \le N를 만족하는 모든 정수 y,zy, z에 대해 f(x,y,z)f(x, y, z)를 모두 합한 값을 g(x)g(x)로 정의하자. g(1),g(2),,g(N)g(1), g(2), \ldots, g(N) 의 값을 모두 구하는 프로그램을 작성하여라.

입력

첫 번째 줄에 NN이 주어진다.

두 번째 줄에 A1,,ANA_1, \ldots, A_N이 공백을 사이에 두고 주어진다.

출력

NN개의 줄을 출력하라. 이 중 ii (1iN1 \le i \le N)번째 줄에는 g(i)g(i)의 값을 출력하라.

제한

  • 주어지는 모든 수는 정수이다.
  • 2N2000002 \le N \le 200\,000
  • 모든 ii (1iN1 \le i \le N)에 대해, 1AiN1 \le A_i \le N.
  • 모든 i,ji, j (1i<jN1 \le i < j \le N)에 대해, AiAjA_i \neq A_j.

서브태스크

번호배점제한
110N15N \le 15.
213N100N \le 100.
317N500N \le 500.
422N5000N \le 5\,000.
538추가 제약 조건 없음.

예제 입출력

예제 입력 1
3
1 2 3
예제 출력 1
3
7
9
예제 입력 2
6
3 1 4 6 5 2
예제 출력 2
10
16
22
34
40
46

출처

올림피아드 한국정보올림피아드 KOI 2023 2차 중등부 4번 고등부 2번
solution.cpp
에디터 불러오는 중...