Page not loading? Try clicking here.
Placeholder

#5196
Subtask

카드 바꾸기 1s 32MB

Problems

N개의 카드가 놓여있다.

편의상 가장 왼쪽에 있는 카드를 1번 카드, 그 다음에 있는 카드를 2번 카드... 가장 오른쪽에 있는 카드가 N번 카드라고 하자.

N개의 카드에는 각각 정수가 하나씩 적혀있다. i번 카드에 적혀있는 수를 x_i라고 하자.

N개의 카드 중 일부에 적혀있는 수들을 적절히 바꾸어서, 

왼쪽에서 오른쪽으로 갈수록 카드에 적혀있는 수들이 일정하게 증가하거나, 감소하거나, 또는 모든 수들이 같도록 하고 싶다.

카드에 적혀있는 수들을 바꿀 때는 정수 값으로만 바꿀 수 있으며, 바꾸는 횟수를 최소화해야 한다.

예를 들어, 아래의 그림과 같이 카드들이 주어졌다고 하자.

이 경우 3번 카드에 적혀있는 수를 3으로 바꾸면 아래와 같이 1씩 증가하도록 할 수 있고, 적혀있는 수를 바꾼 카드의 수는 1개이다.

다음과 같이 모든 카드에 적혀있는 수를 2가 되도록 할 수도 있다. 이때, 적혀있는 수를 바꾼 카드의 수는 2개이다.

가장 왼쪽에 있는 카드부터 가장 오른쪽에 있는 카드까지 각 카드에 적혀있는 수들이 순서대로 주어질 때, 

조건을 만족하도록 하려면 바꿔야 할 카드 수의 최솟값을 구하여라.​


Input

첫 번째 줄에 카드의 수 N이 주어진다.

두 번째 줄에는 각 카드에 적힌 수 x_i가 공백을 사이에 두고 순서대로 주어진다.

[제약조건]

2 \le N \le 500

모든 1 \le i \le N에 대해 -1,000,000 \le x_i \le 1,000,000


Output

첫 번째 줄에 답을 출력한다.


Subtask

# Score Condition
#13

N <= 3

#210

답이 2 이하이다.

#320

최소한의 카드들만 바꿔서 조건을 만족하게 했을 때, 인접한 카드에 적힌 수의 차가 100 이하인 경우가 존재함이 보장된다.

#467

추가 제약 조건 없음.


Example #1

4

1 2 2 4
1

Example #2

5

6 3 3 1 -1
2


Source

KOI 2차 2022 초2/중1

You must sign in to write code.