제한 시간 없음
우측 버튼을 눌러 기기를 연결해주세요.
제출 : 0/20
01
미제출
02
미제출
03
미제출
04
미제출
05
미제출
06
미제출
07
미제출
08
미제출
09
미제출
10
미제출
11
미제출
12
미제출
13
미제출
14
미제출
15
미제출
16
미제출
17
미제출
18
미제출
19
미제출
20
미제출
문제 정보
[일반 프로그래밍 문제] 근묵자흑
쉬움
유형
프로그래밍
배점
100


근묵자흑이라는 말이 있다. "검은 먹을 가까이 하면 검어진다". 이는 좋지 못한 사람과 가까이 하면 악에 물들게 된다고 해석할 수 있다. 이는 사람 뿐만 아니라 숫자도 마찬가지이다. 여러 숫자들을 한 곳에 모아두면 시간이 흘러 모든 숫자가 그 중 가장 작은 수에 맞춰 변하게 된다.

현재 1부터 N까지의 정수가 한 번씩 등장하는 길이 N의 수열이 있다. 여기서 당신은 연속된 K개의 정수를 골라서 한 곳에 잠시 모아둘 수 있다. 시간이 지나면 당신이 고른 K개의 정수들은 K개 중 가장 작은 정수가 된다. 이 시간은 고려하지 않는다. 여기서 이 수열을 모두 같은 수로 만들고자 할 때 최소 몇 번 골라야 하는지 구하는 프로그램을 작성하시오.

예를 들어 4개의 수가 [2, 3, 1, 4]와 같이 있고 K=3일 때, [2, 3, 1, 4]을 고르게 되면 세 수는 2, 3, 1 중 가장 작은 수인 1로 변하게 된다. 이후 [1, 1, 1, 4]가 된다. 아직 4가 남아있으니 [1, 1, 1, 4]를 고르게 되면 [1, 1, 1, 1]이 되고 총 2번만에 모두 같은 수로 만드는 데 성공이다.


입력 형식

첫 줄에 공백으로 구분된 두 정수 N, K가 차례로 주어진다.

  • N은 수열의 길이를 나타내는 2 이상 10만 이하의 자연수다.
  • K는 한 번에 연속적으로 골라야 하는 정수의 개수를 나타내는 2 이상 N 이하의 자연수다.

두 번째 줄에는 공백으로 구분된 N개의 정수가 주어진다.

  • 각 정수는 1부터 N까지의 정수 중 하나이며, 같은 정수가 두 번 이상 나타나지 않는다.


출력 형식

주어진 수열을 모두 같은 수로 만들고자 할 때 골라야 하는 최소 횟수를 출력한다.

입/출력 예시
:
공백
:
줄 바꿈
:
예시 1
입력
43
2314
출력
2
예시 2
입력
83
73184625
출력
4
예시 3
입력
374
31362030196133291125782243418261523283719214321416101227223551733
출력
12
⋇ 입출력 형식을 잘 지켜주세요