시간 제한메모리 제한제출정답맞힌 사람정답 비율
2 초 1024 MB55171631.373%

문제

자카르타에는 $N$개의 송신탑이 있다. 송신탑들은 일직선 상에 위치하며 왼쪽에서 오른쪽으로 $0$부터 $N - 1$까지 번호가 붙어 있다. $0 \le i \le N - 1$인 각 $i$에 대해, 송신탑 $i$의 높이는 $H[i]$ 미터이다. 송신탑들의 높이는 모두 다르다.

어떤 양의 간섭 수치 $\delta$에 대해, 한 쌍의 송신탑 $i$와 $j$ ($0 \le i \lt j \le N - 1$)가 서로 통신할 수 있다는 것은 다음을 모두 만족하는 중개 송신탑 $k$가 존재한다는 것을 의미한다.

  • 송신탑 $i$는 송신탑 $k$의 왼쪽에 위치하고 송신탑 $j$는 송신탑 $k$의 오른쪽에 위치한다. 즉, $i \lt k \lt j$이다.
  • 송신탑 $i$와 $j$의 높이는 최대 $H[k] - \delta$ 미터이다.

팍 뎅클렉은 자신의 새로운 송신 네트워크를 위해 몇 개의 송신탑을 빌리려고 한다. 당신은 다음과 같은 팍 뎅클렉의 질문 $Q$개에 대해 답변해야 한다: 파라미터 $L, R$과 $D$ ($0 \le L \le R \le N - 1$이고 $D > 0$)가 주어지면, 팍 뎅클렉이 빌릴 수 있는 송신탑의 최대 개수는 몇 개인가? 단, 다음을 가정한다:

  • 팍 뎅클렉은 번호 $L$과 $R$ 사이($L$과 $R$ 포함)의 송신탑만 빌릴 수 있고,
  • 간섭 수치 $\delta$는 $D$이고,
  • 팍 뎅클렉이 빌리는 송신탑들은 어떤 쌍을 선택하던지 서로 통신할 수 있어야 한다.

참고로 빌린 두 송신탑이 중개 송신탑 $k$를 이용하여 통신할 수 있을 때, 송신탑 $k$는 빌렸어도 되고 빌리지 않았어도 된다.

구현

다음 함수를 구현해야 한다:

void init(int N, int[] H)
  • $N$: 송신탑의 개수.
  • $H$: 송신탑의 높이를 나타내는 길이 $N$인 배열.
  • 이 함수는 최초에 한번만 호출된다. 이후에 아래에 설명된 max_towers 호출이 이어진다.
int max_towers(int L, int R, int D)
  • $L$, $R$: 송신탑 범위의 경계.
  • $D$: 간섭 수치 $\delta$.
  • 이 함수는 팍 뎅클렉이 빌릴 수 있는 송신탑의 범위가 $L$과 $R$ 사이($L$과 $R$ 포함)로 한정되고 간섭 수치 $\delta$가 $D$일 때 그가 빌릴 수 있는 송신탑의 최대 개수를 리턴해야 한다.
  • 이 함수는 정확히 $Q$번 호출된다.

예제

다음 호출을 생각해보자:

init(7, [10, 20, 60, 40, 50, 30, 70])
max_towers(1, 5, 10)

팍 뎅클렉은 송신탑 $1$, $3$, 그리고 $5$를 빌릴 수 있다. 아래 그림에서 색칠된 사다리꼴이 빌린 송신탑을 나타낸다.

$40 \le 50 - 10$이고 $30 \le 50 - 10$이므로 송신탑 $3$과 $5$는 송신탑 $4$를 중개 송신탑으로 이용해서 서로 통신할 수 있다. 송신탑 $1$과 $3$은 중개 송신탑 $2$를 이용하여 서로 통신할 수 있다. 송신탑 $1$과 $5$는 중개 송신탑 $3$을 이용하여 서로 통신할 수 있다. $3$개보다 더 많은 송신탑을 빌릴 수 있는 방법이 없으므로, 함수는 $3$을 리턴해야 한다.

max_towers(2, 2, 100)

범위에 포함되는 송신탑이 $1$개 밖에 없으므로, 팍 뎅클렉은 오직 $1$개의 송신탑만 빌릴 수 있다. 따라서 함수는 $1$을 리턴해야 한다.

max_towers(0, 6, 17)

팍 뎅클렉은 송신탑 $1$과 $3$을 빌릴 수 있다. $20 \le 60 - 17$이고 $40 \le 60 - 17$이므로 송신탑 $1$과 $3$은 중개 송신탑 $2$를 이용하여 서로 통신할 수 있다. $2$개보다 더 많은 송신탑을 빌릴 수 있는 방법이 없으므로, 함수는 $2$를 리턴해야 한다.

제한

  • $1 \le N \le 100\,000$
  • $1 \le Q \le 100\,000$
  • $1 \le H[i] \le 10^9$ (모든 $0 \le i \le N - 1$)
  • $H[i] \ne H[j]$ (모든 $0 \le i \lt j \le N - 1$)
  • $0 \le L \le R \le N - 1$
  • $1 \le D \le 10^9$

서브태스크

번호배점제한
14

다음을 모두 만족하는 송신탑 $k$ ($0 \le k \le N - 1$)가 존재한다.

  • $0\le i\le k-1$인 모든 $i$에 대해: $H[i] \lt H[i + 1]$이고
  • $k \le i \le N - 2$인 모든 $i$에 대해: $H[i] \gt H[i + 1]$이다.
211

$Q = 1$, $N \le 2000$

312

$Q = 1$

414

$D = 1$

517

$L = 0$, $R = N - 1$

619

모든 max_towers 호출에 대해 $D$ 값이 동일하다.

723

추가적인 제한이 없다.

[{"problem_id":"25440","problem_lang":"0","title":"\uc1a1\uc2e0\ud0d1","description":"<p>\uc790\uce74\ub974\ud0c0\uc5d0\ub294 $N$\uac1c\uc758 \uc1a1\uc2e0\ud0d1\uc774 \uc788\ub2e4. \uc1a1\uc2e0\ud0d1\ub4e4\uc740 \uc77c\uc9c1\uc120 \uc0c1\uc5d0 \uc704\uce58\ud558\uba70 \uc67c\ucabd\uc5d0\uc11c \uc624\ub978\ucabd\uc73c\ub85c $0$\ubd80\ud130 $N - 1$\uae4c\uc9c0 \ubc88\ud638\uac00 \ubd99\uc5b4 \uc788\ub2e4. $0 \\le i \\le N - 1$\uc778 \uac01 $i$\uc5d0 \ub300\ud574, \uc1a1\uc2e0\ud0d1 $i$\uc758 \ub192\uc774\ub294 $H[i]$ \ubbf8\ud130\uc774\ub2e4. \uc1a1\uc2e0\ud0d1\ub4e4\uc758 \ub192\uc774\ub294 \ubaa8\ub450 <strong>\ub2e4\ub974\ub2e4<\/strong>.<\/p>\r\n\r\n<p>\uc5b4\ub5a4 \uc591\uc758 \uac04\uc12d \uc218\uce58 $\\delta$\uc5d0 \ub300\ud574, \ud55c \uc30d\uc758 \uc1a1\uc2e0\ud0d1 $i$\uc640 $j$ ($0 \\le i \\lt j \\le N - 1$)\uac00 \uc11c\ub85c \ud1b5\uc2e0\ud560 \uc218 \uc788\ub2e4\ub294 \uac83\uc740 \ub2e4\uc74c\uc744 \ubaa8\ub450 \ub9cc\uc871\ud558\ub294 \uc911\uac1c \uc1a1\uc2e0\ud0d1 $k$\uac00 \uc874\uc7ac\ud55c\ub2e4\ub294 \uac83\uc744 \uc758\ubbf8\ud55c\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>\uc1a1\uc2e0\ud0d1 $i$\ub294 \uc1a1\uc2e0\ud0d1 $k$\uc758 \uc67c\ucabd\uc5d0 \uc704\uce58\ud558\uace0 \uc1a1\uc2e0\ud0d1 $j$\ub294 \uc1a1\uc2e0\ud0d1 $k$\uc758 \uc624\ub978\ucabd\uc5d0 \uc704\uce58\ud55c\ub2e4. \uc989, $i \\lt k \\lt j$\uc774\ub2e4.<\/li>\r\n\t<li>\uc1a1\uc2e0\ud0d1 $i$\uc640 $j$\uc758 \ub192\uc774\ub294 \ucd5c\ub300 $H[k] - \\delta$ \ubbf8\ud130\uc774\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ud30d \ub385\ud074\ub809\uc740 \uc790\uc2e0\uc758 \uc0c8\ub85c\uc6b4 \uc1a1\uc2e0 \ub124\ud2b8\uc6cc\ud06c\ub97c \uc704\ud574 \uba87 \uac1c\uc758 \uc1a1\uc2e0\ud0d1\uc744 \ube4c\ub9ac\ub824\uace0 \ud55c\ub2e4. \ub2f9\uc2e0\uc740 \ub2e4\uc74c\uacfc \uac19\uc740 \ud30d \ub385\ud074\ub809\uc758 \uc9c8\ubb38 $Q$\uac1c\uc5d0 \ub300\ud574 \ub2f5\ubcc0\ud574\uc57c \ud55c\ub2e4: \ud30c\ub77c\ubbf8\ud130 $L, R$\uacfc $D$ ($0 \\le L \\le R \\le N - 1$\uc774\uace0 $D &gt; 0$)\uac00 \uc8fc\uc5b4\uc9c0\uba74, \ud30d \ub385\ud074\ub809\uc774 \ube4c\ub9b4 \uc218 \uc788\ub294 \uc1a1\uc2e0\ud0d1\uc758 \ucd5c\ub300 \uac1c\uc218\ub294 \uba87 \uac1c\uc778\uac00? \ub2e8, \ub2e4\uc74c\uc744 \uac00\uc815\ud55c\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li>\ud30d \ub385\ud074\ub809\uc740 \ubc88\ud638 $L$\uacfc $R$ \uc0ac\uc774($L$\uacfc $R$ \ud3ec\ud568)\uc758 \uc1a1\uc2e0\ud0d1\ub9cc \ube4c\ub9b4 \uc218 \uc788\uace0,<\/li>\r\n\t<li>\uac04\uc12d \uc218\uce58 $\\delta$\ub294 $D$\uc774\uace0,<\/li>\r\n\t<li>\ud30d \ub385\ud074\ub809\uc774 \ube4c\ub9ac\ub294 \uc1a1\uc2e0\ud0d1\ub4e4\uc740 \uc5b4\ub5a4 \uc30d\uc744 \uc120\ud0dd\ud558\ub358\uc9c0 \uc11c\ub85c \ud1b5\uc2e0\ud560 \uc218 \uc788\uc5b4\uc57c \ud55c\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ucc38\uace0\ub85c \ube4c\ub9b0 \ub450 \uc1a1\uc2e0\ud0d1\uc774 \uc911\uac1c \uc1a1\uc2e0\ud0d1 $k$\ub97c \uc774\uc6a9\ud558\uc5ec \ud1b5\uc2e0\ud560 \uc218 \uc788\uc744 \ub54c, \uc1a1\uc2e0\ud0d1 $k$\ub294 \ube4c\ub838\uc5b4\ub3c4 \ub418\uace0 \ube4c\ub9ac\uc9c0 \uc54a\uc558\uc5b4\ub3c4 \ub41c\ub2e4.<\/p>\r\n","input":"","output":"","hint":"","original":"0","html_title":"0","problem_lang_tcode":"Korean","limit":"<ul>\r\n\t<li>$1 \\le N \\le 100\\,000$<\/li>\r\n\t<li>$1 \\le Q \\le 100\\,000$<\/li>\r\n\t<li>$1 \\le H[i] \\le 10^9$ (\ubaa8\ub4e0 $0 \\le i \\le N - 1$)<\/li>\r\n\t<li>$H[i] \\ne H[j]$ (\ubaa8\ub4e0 $0 \\le i \\lt j \\le N - 1$)<\/li>\r\n\t<li>$0 \\le L \\le R \\le N - 1$<\/li>\r\n\t<li>$1 \\le D \\le 10^9$<\/li>\r\n<\/ul>\r\n","subtask1":"<p>\ub2e4\uc74c\uc744 \ubaa8\ub450 \ub9cc\uc871\ud558\ub294 \uc1a1\uc2e0\ud0d1 $k$ ($0 \\le k \\le N - 1$)\uac00 \uc874\uc7ac\ud55c\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>$0\\le i\\le k-1$\uc778 \ubaa8\ub4e0 $i$\uc5d0 \ub300\ud574: $H[i] \\lt H[i + 1]$\uc774\uace0<\/li>\r\n\t<li>$k \\le i \\le N - 2$\uc778 \ubaa8\ub4e0 $i$\uc5d0 \ub300\ud574: $H[i] \\gt H[i + 1]$\uc774\ub2e4.<\/li>\r\n<\/ul>\r\n","subtask2":"<p>$Q = 1$, $N \\le 2000$<\/p>\r\n","subtask3":"<p>$Q = 1$<\/p>\r\n","subtask4":"<p>$D = 1$<\/p>\r\n","subtask5":"<p>$L = 0$, $R = N - 1$<\/p>\r\n","subtask6":"<p>\ubaa8\ub4e0 <code>max_towers<\/code> \ud638\ucd9c\uc5d0 \ub300\ud574 $D$ \uac12\uc774 \ub3d9\uc77c\ud558\ub2e4.<\/p>\r\n","subtask7":"<p>\ucd94\uac00\uc801\uc778 \uc81c\ud55c\uc774 \uc5c6\ub2e4.<\/p>\r\n","custom_implementation":"<p>\ub2e4\uc74c \ud568\uc218\ub97c \uad6c\ud604\ud574\uc57c \ud55c\ub2e4:<\/p>\r\n\r\n<pre>\r\n<code>void init(int N, int[] H)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$N$: \uc1a1\uc2e0\ud0d1\uc758 \uac1c\uc218.<\/li>\r\n\t<li>$H$: \uc1a1\uc2e0\ud0d1\uc758 \ub192\uc774\ub97c \ub098\ud0c0\ub0b4\ub294 \uae38\uc774 $N$\uc778 \ubc30\uc5f4.<\/li>\r\n\t<li>\uc774 \ud568\uc218\ub294 \ucd5c\ucd08\uc5d0 \ud55c\ubc88\ub9cc \ud638\ucd9c\ub41c\ub2e4. \uc774\ud6c4\uc5d0 \uc544\ub798\uc5d0 \uc124\uba85\ub41c <code>max_towers<\/code> \ud638\ucd9c\uc774 \uc774\uc5b4\uc9c4\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<pre>\r\n<code>int max_towers(int L, int R, int D)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$L$, $R$: \uc1a1\uc2e0\ud0d1 \ubc94\uc704\uc758 \uacbd\uacc4.<\/li>\r\n\t<li>$D$: \uac04\uc12d \uc218\uce58 $\\delta$.<\/li>\r\n\t<li>\uc774 \ud568\uc218\ub294 \ud30d \ub385\ud074\ub809\uc774 \ube4c\ub9b4 \uc218 \uc788\ub294 \uc1a1\uc2e0\ud0d1\uc758 \ubc94\uc704\uac00 $L$\uacfc $R$ \uc0ac\uc774($L$\uacfc $R$ \ud3ec\ud568)\ub85c \ud55c\uc815\ub418\uace0 \uac04\uc12d \uc218\uce58 $\\delta$\uac00 $D$\uc77c \ub54c \uadf8\uac00 \ube4c\ub9b4 \uc218 \uc788\ub294 \uc1a1\uc2e0\ud0d1\uc758 \ucd5c\ub300 \uac1c\uc218\ub97c \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4.<\/li>\r\n\t<li>\uc774 \ud568\uc218\ub294 \uc815\ud655\ud788 $Q$\ubc88 \ud638\ucd9c\ub41c\ub2e4.<\/li>\r\n<\/ul>\r\n","custom_example":"<p>\ub2e4\uc74c \ud638\ucd9c\uc744 \uc0dd\uac01\ud574\ubcf4\uc790:<\/p>\r\n\r\n<pre>\r\n<code>init(7, [10, 20, 60, 40, 50, 30, 70])\r\n<\/code><\/pre>\r\n\r\n<pre>\r\n<code>max_towers(1, 5, 10)\r\n<\/code><\/pre>\r\n\r\n<p>\ud30d \ub385\ud074\ub809\uc740 \uc1a1\uc2e0\ud0d1 $1$, $3$, \uadf8\ub9ac\uace0 $5$\ub97c \ube4c\ub9b4 \uc218 \uc788\ub2e4. \uc544\ub798 \uadf8\ub9bc\uc5d0\uc11c \uc0c9\uce60\ub41c \uc0ac\ub2e4\ub9ac\uaf34\uc774 \ube4c\ub9b0 \uc1a1\uc2e0\ud0d1\uc744 \ub098\ud0c0\ub0b8\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/2604c06b-5a93-4137-b451-ed02abb24243\/-\/preview\/\" style=\"width: 373px; height: 384px;\" \/><\/p>\r\n\r\n<p>$40 \\le 50 - 10$\uc774\uace0 $30 \\le 50 - 10$\uc774\ubbc0\ub85c \uc1a1\uc2e0\ud0d1 $3$\uacfc $5$\ub294 \uc1a1\uc2e0\ud0d1 $4$\ub97c \uc911\uac1c \uc1a1\uc2e0\ud0d1\uc73c\ub85c \uc774\uc6a9\ud574\uc11c \uc11c\ub85c \ud1b5\uc2e0\ud560 \uc218 \uc788\ub2e4. \uc1a1\uc2e0\ud0d1 $1$\uacfc $3$\uc740 \uc911\uac1c \uc1a1\uc2e0\ud0d1 $2$\ub97c \uc774\uc6a9\ud558\uc5ec \uc11c\ub85c \ud1b5\uc2e0\ud560 \uc218 \uc788\ub2e4. \uc1a1\uc2e0\ud0d1 $1$\uacfc $5$\ub294 \uc911\uac1c \uc1a1\uc2e0\ud0d1 $3$\uc744 \uc774\uc6a9\ud558\uc5ec \uc11c\ub85c \ud1b5\uc2e0\ud560 \uc218 \uc788\ub2e4. $3$\uac1c\ubcf4\ub2e4 \ub354 \ub9ce\uc740 \uc1a1\uc2e0\ud0d1\uc744 \ube4c\ub9b4 \uc218 \uc788\ub294 \ubc29\ubc95\uc774 \uc5c6\uc73c\ubbc0\ub85c, \ud568\uc218\ub294 $3$\uc744 \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<pre>\r\n<code>max_towers(2, 2, 100)\r\n<\/code><\/pre>\r\n\r\n<p>\ubc94\uc704\uc5d0 \ud3ec\ud568\ub418\ub294 \uc1a1\uc2e0\ud0d1\uc774 $1$\uac1c \ubc16\uc5d0 \uc5c6\uc73c\ubbc0\ub85c, \ud30d \ub385\ud074\ub809\uc740 \uc624\uc9c1 $1$\uac1c\uc758 \uc1a1\uc2e0\ud0d1\ub9cc \ube4c\ub9b4 \uc218 \uc788\ub2e4. \ub530\ub77c\uc11c \ud568\uc218\ub294 $1$\uc744 \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<pre>\r\n<code>max_towers(0, 6, 17)\r\n<\/code><\/pre>\r\n\r\n<p>\ud30d \ub385\ud074\ub809\uc740 \uc1a1\uc2e0\ud0d1 $1$\uacfc $3$\uc744 \ube4c\ub9b4 \uc218 \uc788\ub2e4. $20 \\le 60 - 17$\uc774\uace0 $40 \\le 60 - 17$\uc774\ubbc0\ub85c \uc1a1\uc2e0\ud0d1 $1$\uacfc $3$\uc740 \uc911\uac1c \uc1a1\uc2e0\ud0d1 $2$\ub97c \uc774\uc6a9\ud558\uc5ec \uc11c\ub85c \ud1b5\uc2e0\ud560 \uc218 \uc788\ub2e4. $2$\uac1c\ubcf4\ub2e4 \ub354 \ub9ce\uc740 \uc1a1\uc2e0\ud0d1\uc744 \ube4c\ub9b4 \uc218 \uc788\ub294 \ubc29\ubc95\uc774 \uc5c6\uc73c\ubbc0\ub85c, \ud568\uc218\ub294 $2$\ub97c \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n","custom_samplegrader":"<p>\uc0d8\ud50c \uadf8\ub808\uc774\ub354\uc758 \uc785\ub825 \uc591\uc2dd\uc740 \ub2e4\uc74c\uacfc \uac19\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1$: $N \\, Q$<\/li>\r\n\t<li>line $2$: $H[0] \\, H[1] \\, \\ldots \\, H[N - 1]$<\/li>\r\n\t<li>line $3 + j$ ($0 \\le j \\le Q - 1$): $L \\, R \\, D$ ($j$\ubc88\uc9f8 \uc9c8\ubb38\uc744 \uc704\ud55c $L$, $R$, $D$\uc784)<\/li>\r\n<\/ul>\r\n\r\n<p>\uc0d8\ud50c \uadf8\ub808\uc774\ub354\ub294 \ub2e4\uc74c \ud615\uc2dd\uc73c\ub85c \ub2f5\uc744 \ucd9c\ub825\ud55c\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1 + j$ ($0 \\le j \\le Q - 1$): $j$\ubc88\uc9f8 <code>max_towers<\/code> \ud638\ucd9c\uc758 \ub9ac\ud134\uac12<\/li>\r\n<\/ul>\r\n","custom_attachment":"<ul>\r\n\t<li><a href=\"https:\/\/upload.acmicpc.net\/aeb00e15-22f0-4223-a71a-2363323093c2\/\">towers.zip<\/a><\/li>\r\n<\/ul>\r\n"},{"problem_id":"25440","problem_lang":"1","title":"Radio Towers","description":"<p>There are $N$ radio towers in Jakarta. The towers are located along a straight line and numbered from $0$ to $N - 1$ from left to right. For each $i$ such that $0 \\le i \\le N - 1$, the height of tower $i$ is $H[i]$ metres. The heights of the towers are&nbsp;<strong>distinct<\/strong>.<\/p>\r\n\r\n<p>For some positive interference value $\\delta$, a pair of towers $i$ and $j$ (where $0 \\le i \\lt j \\le N - 1$) can communicate with each other if and only if there is an intermediary tower $k$, such that<\/p>\r\n\r\n<ul>\r\n\t<li>tower $i$ is to the left of tower $k$ and tower $j$ is to the right of tower $k$, that is, $i \\lt k \\lt j$, and<\/li>\r\n\t<li>the heights of tower $i$ and tower $j$ are both at most $H[k] - \\delta$ metres.<\/li>\r\n<\/ul>\r\n\r\n<p>Pak Dengklek wants to lease some radio towers for his new radio network. Your task is to answer $Q$ questions of Pak Dengklek which are of the following form: given parameters $L, R$ and $D$ ($0 \\le L \\le R \\le N - 1$ and $D &gt; 0$), what is the maximum number of towers Pak Dengklek can lease, assuming that<\/p>\r\n\r\n<ul>\r\n\t<li>Pak Dengklek can only lease towers with indices between $L$ and $R$ (inclusive), and<\/li>\r\n\t<li>the interference value $\\delta$ is $D$, and<\/li>\r\n\t<li>any pair of radio towers that Pak Dengklek leases must be able to communicate with each other.<\/li>\r\n<\/ul>\r\n\r\n<p>Note that two leased towers may communicate using an intermediary tower $k$, regardless of whether tower $k$ is leased or not.<\/p>\r\n","input":"","output":"","hint":"","original":"1","html_title":"0","problem_lang_tcode":"English","limit":"<ul>\r\n\t<li>$1 \\le N \\le 100\\,000$<\/li>\r\n\t<li>$1 \\le Q \\le 100\\,000$<\/li>\r\n\t<li>$1 \\le H[i] \\le 10^9$ (for each $i$ such that $0 \\le i \\le N - 1$)<\/li>\r\n\t<li>$H[i] \\ne H[j]$ (for each $i$ and $j$ such that $0 \\le i \\lt j \\le N - 1$)<\/li>\r\n\t<li>$0 \\le L \\le R \\le N - 1$<\/li>\r\n\t<li>$1 \\le D \\le 10^9$<\/li>\r\n<\/ul>\r\n","subtask1":"<p>There exists a tower $k$ ($0 \\le k \\le N - 1$) such that<\/p>\r\n\r\n<ul>\r\n\t<li>for each $i$ such that $0\\le i\\le k-1$: $H[i] \\lt H[i + 1]$, and<\/li>\r\n\t<li>for each $i$ such that $k \\le i \\le N - 2$: $H[i] \\gt H[i + 1]$.<\/li>\r\n<\/ul>\r\n","subtask2":"<p>$Q = 1$, $N \\le 2000$<\/p>\r\n","subtask3":"<p>$Q = 1$<\/p>\r\n","subtask4":"<p>$D = 1$<\/p>\r\n","subtask5":"<p>$L = 0$, $R = N - 1$<\/p>\r\n","subtask6":"<p>The value of $D$ is the same across all&nbsp;<code>max_towers<\/code>&nbsp;calls.<\/p>\r\n","subtask7":"<p>No additional constraints.<\/p>\r\n","custom_implementation":"<p>You should implement the following procedures:<\/p>\r\n\r\n<pre>\r\n<code>void init(int N, int[] H)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$N$: the number of radio towers.<\/li>\r\n\t<li>$H$: an array of length $N$ describing the tower heights.<\/li>\r\n\t<li>This procedure is called exactly once, before any calls to <code>max_towers<\/code>.<\/li>\r\n<\/ul>\r\n\r\n<pre>\r\n<code>int max_towers(int L, int R, int D)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$L$, $R$: the boundaries of a range of towers.<\/li>\r\n\t<li>$D$: the value of $\\delta$.<\/li>\r\n\t<li>This procedure should return the maximum number of radio towers Pak Dengklek can lease for his new radio network if he is only allowed to lease towers between tower $L$ and tower $R$ (inclusive) and the value of $\\delta$ is $D$.<\/li>\r\n\t<li>This procedure is called exactly $Q$ times.<\/li>\r\n<\/ul>\r\n","custom_example":"<p>Consider the following sequence of calls:<\/p>\r\n\r\n<pre>\r\n<code>init(7, [10, 20, 60, 40, 50, 30, 70])\r\n<\/code><\/pre>\r\n\r\n<pre>\r\n<code>max_towers(1, 5, 10)\r\n<\/code><\/pre>\r\n\r\n<p>Pak Dengklek can lease towers $1$, $3$, and $5$. The example is illustrated in the following picture, where shaded trapezoids represent leased towers.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/2604c06b-5a93-4137-b451-ed02abb24243\/-\/preview\/\" style=\"width: 373px; height: 384px;\" \/><\/p>\r\n\r\n<p>Towers $3$ and $5$ can communicate using tower $4$ as an intermediary, since $40 \\le 50 - 10$ and $30 \\le 50 - 10$. Towers $1$ and $3$ can communicate using tower $2$ as an intermediary. Towers $1$ and $5$ can communicate using tower $3$ as an intermediary. There is no way to lease more than $3$ towers, therefore the procedure should return $3$.<\/p>\r\n\r\n<pre>\r\n<code>max_towers(2, 2, 100)\r\n<\/code><\/pre>\r\n\r\n<p>There is only $1$ tower in the range, thus Pak Dengklek can only lease $1$ tower. Therefore the procedure should return $1$.<\/p>\r\n\r\n<pre>\r\n<code>max_towers(0, 6, 17)\r\n<\/code><\/pre>\r\n\r\n<p>Pak Dengklek can lease towers $1$ and $3$. Towers $1$ and $3$ can communicate using tower $2$ as an intermediary, since $20 \\le 60 - 17$ and $40 \\le 60 - 17$. There is no way to lease more than $2$ towers, therefore the procedure should return $2$.<\/p>\r\n","custom_samplegrader":"<p>The sample grader reads the input in the following format:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1$: $N \\, Q$<\/li>\r\n\t<li>line $2$: $H[0] \\, H[1] \\, \\ldots \\, H[N - 1]$<\/li>\r\n\t<li>line $3 + j$ ($0 \\le j \\le Q - 1$): $L \\, R \\, D$ for question $j$<\/li>\r\n<\/ul>\r\n\r\n<p>The sample grader prints your answers in the following format:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1 + j$ ($0 \\le j \\le Q - 1$): the return value of <code>max_towers<\/code> for question $j$<\/li>\r\n<\/ul>\r\n","custom_attachment":"<ul>\r\n\t<li><a href=\"https:\/\/upload.acmicpc.net\/aeb00e15-22f0-4223-a71a-2363323093c2\/\">towers.zip<\/a><\/li>\r\n<\/ul>\r\n"}]

샘플 그레이더

샘플 그레이더의 입력 양식은 다음과 같다:

  • line $1$: $N \, Q$
  • line $2$: $H[0] \, H[1] \, \ldots \, H[N - 1]$
  • line $3 + j$ ($0 \le j \le Q - 1$): $L \, R \, D$ ($j$번째 질문을 위한 $L$, $R$, $D$임)

샘플 그레이더는 다음 형식으로 답을 출력한다:

  • line $1 + j$ ($0 \le j \le Q - 1$): $j$번째 max_towers 호출의 리턴값

첨부

출처

Olympiad > International Olympiad in Informatics > IOI 2022 > Day 1 3번

  • 문제를 만든 사람: Kevin Luiz Ponte Pucci

제출할 수 있는 언어

C++17, C++20, C++17 (Clang), C++20 (Clang)

채점 및 기타 정보

  • 예제는 채점하지 않는다.
  • 이 문제의 채점 우선 순위는 2이다.