PivotOJ

지그재그

시간 제한: 2000ms메모리 제한: 1024MB출처: KOI 2023 2차BOJ 28327

문제

길이가 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)의 값을 출력하라.

예제

예제 1

입력
3
1 2 3
출력
3
7
9

예제 2

입력
6
3 1 4 6 5 2
출력
10
16
22
34
40
46
코드를 제출하려면 로그인하세요.