Logo
(追記) (追記ここまで)

32397번 - 차이를 $M$ 이하로

시간 제한메모리 제한제출정답맞힌 사람정답 비율
3 초 1024 MB124544346.237%

문제

동우는 길이 $N$의 수열 $A=\left[ A_1,A_2,\cdots ,A_N \right]$을 분석하고 있다. 동우는 한 번의 시행으로 수열 $A$의 한 항 $A_i$를 원하는 정수로 바꿀 수 있다. 귀찮음이 많은 동우는 가능한 최소한의 시행으로 모든 이웃한 항의 차이를 $M$ 이하로 만들고 싶어 한다. 즉, 모든 1ドル\leq i<N$에 대하여 $\lvert A_{i+1}-A_i\rvert\leq M$으로 만드는 것이 목표이다. 동우를 도와 필요한 최소 시행 횟수를 구해보자.

입력

첫 번째 줄에 정수 $N(1\leq N\leq 10^6)$과 $M(1\leq M\leq 10^{12})$이 공백으로 구분되어 주어진다.

두 번째 줄에 $N$개의 정수 $A_1,A_2,\cdots ,A_N(1\leq A_i\leq 10^{12})$이 공백으로 구분되어 주어진다.

출력

첫 번째 줄에 모든 이웃한 항의 차이를 $M$ 이하로 만들기 위해 필요한 최소 시행 횟수를 출력한다.

만약 불가능하다면 -1을 출력한다.

제한

예제 입력 1

9 3
1 2 2 1 3 3 7 7 1

예제 출력 1

2

예제 입력 2

10 5
2 8 7 5 15 18 17 20 5 16

예제 출력 2

3

힌트

출처

University > 고려대학교 > 고려대학교 프로그래밍 경시대회 > 2024 고려대학교 프로그래밍 경시대회 (KCPC) > 예비소집 C번

(追記) (追記ここまで)

출처

대학교 대회

  • 사업자 등록 번호: 541-88-00682
  • 대표자명: 최백준
  • 주소: 서울시 서초구 서초대로74길 29 서초파라곤 412호
  • 전화번호: 02-521-0487 (이메일로 연락 주세요)
  • 이메일: contacts@startlink.io
  • 통신판매신고번호: 제 2017-서울서초-2193 호

AltStyle によって変換されたページ (->オリジナル) /