Išmaniosios svarstyklės | 프로그래밍의 벗 PivotOJ
PivotOJ

Išmaniosios svarstyklės

시간 제한: 1000ms메모리 제한: 1024MB출처: LMIO 2018-2019BOJ 30066
이 문제는 본문 이미지 일부가 표시되지 않습니다. 텍스트만으로 풀이가 어려울 수 있습니다.

문제

Martynas nusipirko išmaniąsias svarstykles ir nori sukurti programėlę savo svoriui sekti. Tačiau svarstyklėmis naudosis ne jis vienas – kartais pasinaudos svečiai, draugai, arba ant svarstyklių gali netyčia užlipti ir jo katinas.

Martynas sugalvojo algoritmą, kaip sekti, kiek skirtingų klientų naudojasi svarstyklėmis. Iš pradžių, svarstyklėmis nesinaudoja nei vienas klientas. Kai yra naujas matavimas, jis priskiriamas klientui pagal tokias taisykles:

  1. Jei matavimas nuo visų esamų klientų paskutinio svorio matavimo skiriasi daugiau negu DD gramų, tai laikoma, kad sveriasi naujas klientas ir jis yra užregistruojamas.
  2. Priešingu atveju, matavimas priskiriamas tam klientui, kurio paskutinis svorio matavimas yra artimiausias šiam matavimui.
  3. Jei yra keli klientai, kuriems tinka sąlyga (2), matavimas priskiriamas tam klientui, kurio paskutinis svorio matavimas yra mažesnis.

Pavyzdžiui, tarkime, jog svarstyklės užregistravo tokius matavimus iš eilės:

  1. 7500075000 gramų: Martynas pasisvėrė ryte.
  2. 7550075500 gramų: Martynas pasisvėrė vakare.
  3. 30003000 gramų: Pasisvėrė katinas.
  4. 7850078500 gramų: Martyno draugas išbandė svarstykles.
  5. 29502950 gramų: Ant svarstyklių vėl užlipo katinas.
  6. 7700077000 gramų: Vėl pasisvėrė Martynas (pavalgęs).

Su parametru D=1500D = 1500, Martyno algoritmas sugebėtų teisingai atskirti, jog svartyklėmis iš viso naudojosi trys klientai:

[이미지 1]

Jums duota NN svorio matavimų, kuriuos užregistravo išmaniosios svarstyklės, ir parametras DD. Pagal Martyno sugalvotą algoritmą suskaičiuokite, kiek skirtingų klientų (žmonių, katinų, pelių...) iš viso pasinaudojo svarstyklėmis.

입력

Pirmoje eilutėje įrašyti su sveikieji skaičiai NN ir DD. Toliau seka NN eilučių, kuriose įrašyta po vieną svorio matavimą mim_i (gramais).

출력

Išveskite vieną skaičių – kiek klientų pasinaudojo išmaniosiomis svarstyklėmis.

예제

예제 1

입력
6 1500
75000
75500
3000
78500
2950
77000
출력
3

예제 2

입력
8 2000
60000
61000
79000
62000
81000
60000
59000
80000
출력
2
코드를 제출하려면 로그인하세요.