시간 제한 메모리 제한 제출 정답 맞은 사람 정답 비율
2 초 512 MB 18 3 3 33.333%

문제

신도시의 도시 계획을 세우려고 한다. 신도시의 어느 곳에 고층 빌딩과 공원을 지을지 결정해야 한다. 신도시는 R x C 개의 단지로 구성되어 있으며, R개의 행 C개의 열로 구성된 격자 모양으로 나타낸다. 예를 들어, 아래 그림은 2개의 행과 3개의 열로 구성된 신도시를 나타낸다. 총 여섯 개의 단지가 있다. 각각의 단지는 해발 고도를 나타내는 정수 값을 하나씩 가지고 있다.

신도시에 고층 빌딩과 공원을 지을 때는 아래 조건을 모두 만족해야 한다.

  1. 고층 건물 하나는 단지 하나 위에 지어져야 한다. 즉, 고층 건물을 단지 두 개에 걸쳐서 지을 수 없다.
  2. 각각의 단지에는 고층 건물이 하나 있거나, 공원의 일부이어야 한다.
  3. 고층 건물이 지어진 곳의 해발 고도가 y라면, 해발 고도가 y이하인 모든 단지에도 고층 건물이 있어야 한다.
  4. 공원은 인접한 두 개의 단지 위에 지어야 하고, 두 개의 서로 다른 공원이 겹치면 안 된다. 즉, 단지 하나가 공원 2개에 포함될 수는 없다. 또, 공원이 단지 격자를 벗어나면 안 된다.

3번 조건 때문에, 도시 계획을 세울 때는 음이 아닌 정수 Z를 먼저 골라야 한다. 그 다음, 해발 고도가 Z 이하인 모든 단지에 고층 건물을 짓고, 나머지 단지에는 공원을 지으려고 한다. 공원은 두 개의 인접한 단지 위에 지어야 한다. 두 단지가 도로를 공유할 때, 두 단지를 인접하다고 한다.

공원 하나를 짓는데는 D원이 필요하다. 고층 빌딩 전체를 짓는 비용은 Z×W원이다. 

위의 모든 조건을 만족하면서, 고층 빌딩과 공원을 짓는 비용의 최솟값을 구하는 프로그램을 작성하시오.

입력

첫 줄에 4개의 정수 R, C, D, W 가 주어진다 (1 ≤ R, C ≤ 50 그리고 1 ≤ D, W ≤ 109). 다음 R줄에는 각 줄에 C개의 정수가 주어진다. 이 수는 각 단지의 y값을 나타낸다. 각 y값은 1 이상 109 이하이다.

출력

첫 줄에 고층 건물과 공원을 모든 단지에 짓는데 필요한 최소 비용을 출력하라.

서브태스크 1 (6점)

  • 1 ≤ R, C ≤ 5
  • 1 ≤ D, W, y ≤ 100

서브태스크 2 (11점)

  • 1 ≤ R, C ≤ 20
  • 1 ≤ D, W, y ≤ 1,000,000

서브태스크 3 (13점)

  • 1 ≤ R, C ≤ 50
  • 1 ≤ D, W, y ≤ 1,000,000,000

예제 입력 1

2 3 120 10
10 30 20
40 20 10

예제 출력 1

340

Z = 10을 고르면 고층 건물을 두 단지에 짓고 (10×10 = 100원) 나머지 네 단지에 두 개의 공원을 짓게 된다 (120×2 = 240원). 총 비용이 340원이고, 이 예제에서의 최소 비용이다.

만약 Z = 0을 고를 경우 총 360원이 필요하며, Z = 40을 고를 경우 총 400원이 필요하다. Z = 20을 고른다면, 총 네 단지에 고층 건물을 짓게 되는데, 이 경우 남아있는 두 단지에 공원을 지을 수 있는 방법이 없다. 이는 아래 그림에서 확인할 수 있다. 


 

예제 입력 2

1 2 76 59
62 77

예제 출력 2

76

예제 입력 3

1 4 71 87
41 2 95 68

예제 출력 3

142

예제 입력 4

3 3 16 12
58 90 8
81 38 94
12 56 80

예제 출력 4

160

예제 입력 5

4 4 71 3
85 86 97 99
30 74 50 88
77 78 34 83
59 26 54 63

예제 출력 5

297

힌트

Python을 사용하는 참가자는 PyPy 사용을 권장 합니다.

위의 그림 예제의 경우에, Z를 10으로 고른다면 좌상단과 우하단에 위치한 단지에 고층 건물을 짓고, 나머지 단지에는 공원을 두 개 지을 수 있다.

아래 세 예제는 이 규칙을 따르지 않고 공원을 지은 경우를 나타낸다. 


 

왼쪽 예제는 공원이 도시 격자를 벗어난 경우를 나타낸다. 중간 예제는 두 개의 공원이 겹쳐서 하나의 단지 위에 지어진 경우를 나타낸다. 상단 중간 단지를 공유하고 있다. 우측 예제는 공원이 두 개의 인접한 단지 위에 지어지지 않은 경우를 나타낸다. 이 세 경우 모두 공원을 잘못 지은 경우이다.

[{"problem_id":"15934","problem_lang":"0","title":"\ub3c4\uc2dc \uacc4\ud68d","description":"<p>\uc2e0\ub3c4\uc2dc\uc758 \ub3c4\uc2dc \uacc4\ud68d\uc744 \uc138\uc6b0\ub824\uace0 \ud55c\ub2e4. \uc2e0\ub3c4\uc2dc\uc758 \uc5b4\ub290 \uacf3\uc5d0&nbsp;\uace0\uce35 \ube4c\ub529\uacfc \uacf5\uc6d0\uc744 \uc9c0\uc744\uc9c0 \uacb0\uc815\ud574\uc57c \ud55c\ub2e4. \uc2e0\ub3c4\uc2dc\ub294 R x C \uac1c\uc758 \ub2e8\uc9c0\ub85c \uad6c\uc131\ub418\uc5b4 \uc788\uc73c\uba70, R\uac1c\uc758 \ud589 C\uac1c\uc758 \uc5f4\ub85c \uad6c\uc131\ub41c \uaca9\uc790 \ubaa8\uc591\uc73c\ub85c \ub098\ud0c0\ub0b8\ub2e4. \uc608\ub97c \ub4e4\uc5b4, \uc544\ub798 \uadf8\ub9bc\uc740 2\uac1c\uc758 \ud589\uacfc 3\uac1c\uc758 \uc5f4\ub85c \uad6c\uc131\ub41c \uc2e0\ub3c4\uc2dc\ub97c \ub098\ud0c0\ub0b8\ub2e4.&nbsp;\ucd1d \uc5ec\uc12f \uac1c\uc758 \ub2e8\uc9c0\uac00 \uc788\ub2e4. \uac01\uac01\uc758 \ub2e8\uc9c0\ub294 \ud574\ubc1c \uace0\ub3c4\ub97c \ub098\ud0c0\ub0b4\ub294 \uc815\uc218 \uac12\uc744 \ud558\ub098\uc529 \uac00\uc9c0\uace0 \uc788\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/62258ff9-e897-4dee-82a4-4862b8084cbe\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><\/p>\r\n\r\n<p>\uc2e0\ub3c4\uc2dc\uc5d0 \uace0\uce35 \ube4c\ub529\uacfc \uacf5\uc6d0\uc744 \uc9c0\uc744 \ub54c\ub294 \uc544\ub798 \uc870\uac74\uc744 \ubaa8\ub450 \ub9cc\uc871\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<ol>\r\n\t<li>\uace0\uce35 \uac74\ubb3c \ud558\ub098\ub294&nbsp;\ub2e8\uc9c0 \ud558\ub098 \uc704\uc5d0 \uc9c0\uc5b4\uc838\uc57c \ud55c\ub2e4. \uc989, \uace0\uce35 \uac74\ubb3c\uc744 \ub2e8\uc9c0 \ub450 \uac1c\uc5d0 \uac78\uccd0\uc11c \uc9c0\uc744 \uc218 \uc5c6\ub2e4.<\/li>\r\n\t<li>\uac01\uac01\uc758 \ub2e8\uc9c0\uc5d0\ub294 \uace0\uce35 \uac74\ubb3c\uc774 \ud558\ub098 \uc788\uac70\ub098, \uacf5\uc6d0\uc758 \uc77c\ubd80\uc774\uc5b4\uc57c \ud55c\ub2e4.<\/li>\r\n\t<li>\uace0\uce35 \uac74\ubb3c\uc774 \uc9c0\uc5b4\uc9c4 \uacf3\uc758 \ud574\ubc1c \uace0\ub3c4\uac00 y\ub77c\uba74, \ud574\ubc1c \uace0\ub3c4\uac00 y\uc774\ud558\uc778 \ubaa8\ub4e0 \ub2e8\uc9c0\uc5d0\ub3c4 \uace0\uce35 \uac74\ubb3c\uc774 \uc788\uc5b4\uc57c \ud55c\ub2e4.<\/li>\r\n\t<li>\uacf5\uc6d0\uc740 \uc778\uc811\ud55c \ub450 \uac1c\uc758 \ub2e8\uc9c0 \uc704\uc5d0 \uc9c0\uc5b4\uc57c \ud558\uace0, \ub450 \uac1c\uc758 \uc11c\ub85c \ub2e4\ub978 \uacf5\uc6d0\uc774 \uacb9\uce58\uba74 \uc548 \ub41c\ub2e4. \uc989, \ub2e8\uc9c0 \ud558\ub098\uac00 \uacf5\uc6d0 2\uac1c\uc5d0 \ud3ec\ud568\ub420 \uc218\ub294 \uc5c6\ub2e4. \ub610, \uacf5\uc6d0\uc774 \ub2e8\uc9c0 \uaca9\uc790\ub97c \ubc97\uc5b4\ub098\uba74 \uc548 \ub41c\ub2e4.<\/li>\r\n<\/ol>\r\n\r\n<p>3\ubc88 \uc870\uac74 \ub54c\ubb38\uc5d0, \ub3c4\uc2dc \uacc4\ud68d\uc744 \uc138\uc6b8 \ub54c\ub294 \uc74c\uc774 \uc544\ub2cc \uc815\uc218 Z\ub97c \uba3c\uc800 \uace8\ub77c\uc57c \ud55c\ub2e4. \uadf8 \ub2e4\uc74c, \ud574\ubc1c \uace0\ub3c4\uac00 Z \uc774\ud558\uc778 \ubaa8\ub4e0 \ub2e8\uc9c0\uc5d0 \uace0\uce35 \uac74\ubb3c\uc744 \uc9d3\uace0, \ub098\uba38\uc9c0 \ub2e8\uc9c0\uc5d0\ub294 \uacf5\uc6d0\uc744 \uc9c0\uc73c\ub824\uace0 \ud55c\ub2e4. \uacf5\uc6d0\uc740 \ub450 \uac1c\uc758 \uc778\uc811\ud55c \ub2e8\uc9c0 \uc704\uc5d0 \uc9c0\uc5b4\uc57c \ud55c\ub2e4. \ub450 \ub2e8\uc9c0\uac00 \ub3c4\ub85c\ub97c \uacf5\uc720\ud560 \ub54c, \ub450 \ub2e8\uc9c0\ub97c \uc778\uc811\ud558\ub2e4\uace0 \ud55c\ub2e4.<\/p>\r\n\r\n<p>\uacf5\uc6d0 \ud558\ub098\ub97c \uc9d3\ub294\ub370\ub294 D\uc6d0\uc774 \ud544\uc694\ud558\ub2e4. \uace0\uce35 \ube4c\ub529 \uc804\uccb4\ub97c \uc9d3\ub294 \ube44\uc6a9\uc740 Z&times;W\uc6d0\uc774\ub2e4.&nbsp;<\/p>\r\n\r\n<p>\uc704\uc758 \ubaa8\ub4e0 \uc870\uac74\uc744 \ub9cc\uc871\ud558\uba74\uc11c, \uace0\uce35 \ube4c\ub529\uacfc \uacf5\uc6d0\uc744 \uc9d3\ub294 \ube44\uc6a9\uc758 \ucd5c\uc19f\uac12\uc744 \uad6c\ud558\ub294 \ud504\ub85c\uadf8\ub7a8\uc744 \uc791\uc131\ud558\uc2dc\uc624.<\/p>\r\n","input":"<p>\uccab \uc904\uc5d0 4\uac1c\uc758 \uc815\uc218 R, C, D, W \uac00 \uc8fc\uc5b4\uc9c4\ub2e4 (1 &le; R, C &le; 50 \uadf8\ub9ac\uace0 1 &le; D, W &le; 10<sup>9<\/sup>). \ub2e4\uc74c R\uc904\uc5d0\ub294 \uac01 \uc904\uc5d0 C\uac1c\uc758 \uc815\uc218\uac00 \uc8fc\uc5b4\uc9c4\ub2e4. \uc774 \uc218\ub294 \uac01 \ub2e8\uc9c0\uc758 y\uac12\uc744 \ub098\ud0c0\ub0b8\ub2e4. \uac01 y\uac12\uc740 1 \uc774\uc0c1 10<sup>9<\/sup> \uc774\ud558\uc774\ub2e4.<\/p>\r\n","output":"<p>\uccab \uc904\uc5d0 \uace0\uce35 \uac74\ubb3c\uacfc \uacf5\uc6d0\uc744 \ubaa8\ub4e0 \ub2e8\uc9c0\uc5d0 \uc9d3\ub294\ub370 \ud544\uc694\ud55c \ucd5c\uc18c \ube44\uc6a9\uc744 \ucd9c\ub825\ud558\ub77c.<\/p>\r\n","hint":"<p>Python\uc744 \uc0ac\uc6a9\ud558\ub294 \ucc38\uac00\uc790\ub294 PyPy \uc0ac\uc6a9\uc744 \uad8c\uc7a5 \ud569\ub2c8\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/62258ff9-e897-4dee-82a4-4862b8084cbe\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><\/p>\r\n\r\n<p>\uc704\uc758 \uadf8\ub9bc \uc608\uc81c\uc758 \uacbd\uc6b0\uc5d0, Z\ub97c 10\uc73c\ub85c \uace0\ub978\ub2e4\uba74 \uc88c\uc0c1\ub2e8\uacfc \uc6b0\ud558\ub2e8\uc5d0 \uc704\uce58\ud55c \ub2e8\uc9c0\uc5d0 \uace0\uce35 \uac74\ubb3c\uc744 \uc9d3\uace0, \ub098\uba38\uc9c0 \ub2e8\uc9c0\uc5d0\ub294 \uacf5\uc6d0\uc744 \ub450 \uac1c \uc9c0\uc744 \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/e24205a1-1e9a-4153-a012-5104bdb352d9\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><\/p>\r\n\r\n<p>\uc544\ub798 \uc138 \uc608\uc81c\ub294 \uc774 \uaddc\uce59\uc744 \ub530\ub974\uc9c0 \uc54a\uace0 \uacf5\uc6d0\uc744 \uc9c0\uc740 \uacbd\uc6b0\ub97c \ub098\ud0c0\ub0b8\ub2e4.&nbsp;<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/bbed5636-00a0-4c77-997c-67fde229350b\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/f02c0644-597a-47e0-9ff6-124de86f8141\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/856bd1ff-af93-41f9-a749-5f9c8b9eb465\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><br \/>\r\n&nbsp;<\/p>\r\n\r\n<p>\uc67c\ucabd \uc608\uc81c\ub294 \uacf5\uc6d0\uc774 \ub3c4\uc2dc \uaca9\uc790\ub97c \ubc97\uc5b4\ub09c \uacbd\uc6b0\ub97c \ub098\ud0c0\ub0b8\ub2e4. \uc911\uac04 \uc608\uc81c\ub294 \ub450 \uac1c\uc758 \uacf5\uc6d0\uc774 \uacb9\uccd0\uc11c \ud558\ub098\uc758 \ub2e8\uc9c0 \uc704\uc5d0 \uc9c0\uc5b4\uc9c4 \uacbd\uc6b0\ub97c \ub098\ud0c0\ub0b8\ub2e4. \uc0c1\ub2e8 \uc911\uac04 \ub2e8\uc9c0\ub97c \uacf5\uc720\ud558\uace0 \uc788\ub2e4. \uc6b0\uce21 \uc608\uc81c\ub294 \uacf5\uc6d0\uc774 \ub450 \uac1c\uc758 \uc778\uc811\ud55c \ub2e8\uc9c0 \uc704\uc5d0 \uc9c0\uc5b4\uc9c0\uc9c0 \uc54a\uc740 \uacbd\uc6b0\ub97c \ub098\ud0c0\ub0b8\ub2e4. \uc774 \uc138 \uacbd\uc6b0 \ubaa8\ub450 \uacf5\uc6d0\uc744 \uc798\ubabb \uc9c0\uc740 \uacbd\uc6b0\uc774\ub2e4.<\/p>\r\n","original":"1","problem_lang_code":"\ud55c\uad6d\uc5b4","subtask1":"<ul>\r\n\t<li>1 &le; R, C &le; 5<\/li>\r\n\t<li>1 &le; D, W, y &le; 100<\/li>\r\n<\/ul>\r\n","subtask2":"<ul>\r\n\t<li>1 &le; R, C &le; 20<\/li>\r\n\t<li>1 &le; D, W, y &le; 1,000,000<\/li>\r\n<\/ul>\r\n","subtask3":"<ul>\r\n\t<li>1 &le; R, C &le; 50<\/li>\r\n\t<li>1 &le; D, W, y &le;&nbsp;1,000,000,000<\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>Z = 10\uc744 \uace0\ub974\uba74 \uace0\uce35 \uac74\ubb3c\uc744 \ub450 \ub2e8\uc9c0\uc5d0 \uc9d3\uace0 (10&times;10 = 100\uc6d0) \ub098\uba38\uc9c0 \ub124 \ub2e8\uc9c0\uc5d0 \ub450 \uac1c\uc758 \uacf5\uc6d0\uc744 \uc9d3\uac8c \ub41c\ub2e4 (120&times;2 = 240\uc6d0). \ucd1d \ube44\uc6a9\uc774 340\uc6d0\uc774\uace0, \uc774 \uc608\uc81c\uc5d0\uc11c\uc758 \ucd5c\uc18c \ube44\uc6a9\uc774\ub2e4.<\/p>\r\n\r\n<p>\ub9cc\uc57d Z = 0\uc744 \uace0\ub97c \uacbd\uc6b0 \ucd1d 360\uc6d0\uc774 \ud544\uc694\ud558\uba70, Z = 40\uc744 \uace0\ub97c \uacbd\uc6b0 \ucd1d 400\uc6d0\uc774 \ud544\uc694\ud558\ub2e4.&nbsp;Z = 20\uc744 \uace0\ub978\ub2e4\uba74, \ucd1d \ub124 \ub2e8\uc9c0\uc5d0 \uace0\uce35 \uac74\ubb3c\uc744 \uc9d3\uac8c \ub418\ub294\ub370, \uc774 \uacbd\uc6b0 \ub0a8\uc544\uc788\ub294 \ub450 \ub2e8\uc9c0\uc5d0 \uacf5\uc6d0\uc744 \uc9c0\uc744 \uc218 \uc788\ub294 \ubc29\ubc95\uc774 \uc5c6\ub2e4. \uc774\ub294 \uc544\ub798 \uadf8\ub9bc\uc5d0\uc11c \ud655\uc778\ud560 \uc218 \uc788\ub2e4.&nbsp;<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/1ee5c4e1-6db0-47f9-a95b-028a5f185134\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><br \/>\r\n&nbsp;<\/p>\r\n"},{"problem_id":"15934","problem_lang":"1","title":"City Planning","description":"<p>You have been appointed as the director of city planning, and your main role is to determine where skyscrapers to be built and where parks will be built. The city consists of R x C city blocks such that blocks are laid out in R rows and C columns (you can consider it as a grid of size R x C). Different city blocks are different distances above the sea level, which makes constructions difficult. Each city block is currently empty, and the goal is to build something on every block -- whether it is a skyscraper or a park. For instance, the following image shows a city grid that consists of two rows and three columns (totaling six city blocks). Each city block has an associated integer value with it, which tell how many meters the block is above the sea level.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/62258ff9-e897-4dee-82a4-4862b8084cbe\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><\/p>\r\n\r\n<p>The city council asked you to find a way to build skyscrapers and parks, while meeting the following rules.<\/p>\r\n\r\n<ol>\r\n\t<li>A skyscraper must be built on a single city block (it can occupy only one city block).<\/li>\r\n\t<li>Each city block must either have a skyscraper built on it OR have no skyscraper but a part of a park built on it.<\/li>\r\n\t<li>If a skyscraper is built on a city block of level y, then all city blocks that are at most y meters above the sea level must also have a skyscraper (on each of them).&nbsp;<\/li>\r\n\t<li>Each park must be built on two adjacent city blocks, and no two parks can overlap (share the same city block). In particular, no park can be built out of the city grid (the R x C grid).<\/li>\r\n<\/ol>\r\n\r\n<p>Because of the third rule, you must first choose some non-negative integer Z such that all city blocks that are at most Z meters above the sea level will have skyscrapers built on -- this makes the construction much easier. The remaining city blocks (that do not have skyscrapers on them) will have parks built. The citizens do not like small parks, and therefore each park requires two adjacent blocks in order to be properly constructed (this is the fourth rule). Two city blocks are adjacent if they share a road (or an edge) between them, but not diagonally (hence each city block has at most four adjacent city blocks).<\/p>\r\n\r\n<p>The city council asks you to compute the minimum cost of building skyscrapers and parks while meeting the above conditions. Each park (occupying two adjacent city blocks) costs D dollars. For skyscrapers, for your choice of Z (non-negative integer), the total cost will be Z &times;&nbsp;W dollars where W is a positive integer constant. Recall that you get to choose the value of Z, and all city blocks that are at most Z meters above the sea level (whose Y-values are at most Z) will have skyscrapers on them.<\/p>\r\n\r\n<p>Given these requirements, compute the minimum cost of building skyscrapers and parks such that no city block is left empty.<\/p>\r\n","input":"<p>The first line will contain four integers R, C, D, and W where 1 &le; R, C &le; 50 and 1 &le; D, W &le;&nbsp;10<sup>9<\/sup>. Each of the following R lines will contain C numbers each, decribing the y values of the city blocks. The value of each y&nbsp;is between 1 and 10<sup>9<\/sup>, inclusive.<\/p>\r\n","output":"<p>You must output the minimum cost of buildling skyscrapers and parks.&nbsp;<\/p>\r\n","hint":"<p>For Python users, using PyPy is recommended.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/62258ff9-e897-4dee-82a4-4862b8084cbe\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><\/p>\r\n\r\n<p>In the same example as above, if you choose Z = 10, for instance, two skyscrapers will be built on two city blocks (on the top-left and bottom-right city blocks), and two parks can be built on the remaining four city blocks. This is demonstrated in the following image.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/e24205a1-1e9a-4153-a012-5104bdb352d9\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><\/p>\r\n\r\n<p>The following three examples show what is NOT allowed when it comes to building a park.&nbsp;<\/p>\r\n\r\n<p>In the left example, a park is partially built on the bottom-left city block, which is not allowed as it goes beyond the city grid. In the middle example, two parks are overlapping on the same city block (the top-middle block). In the right example, a park is not built on two adjacent city blocks. All these examples show wrong ways of building parks, which will not be approved by the city council.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/bbed5636-00a0-4c77-997c-67fde229350b\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/f02c0644-597a-47e0-9ff6-124de86f8141\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/856bd1ff-af93-41f9-a749-5f9c8b9eb465\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><\/p>\r\n","original":"0","problem_lang_code":"\uc601\uc5b4","subtask1":"<ul>\r\n\t<li>1 &le; R, C &le; 5<\/li>\r\n\t<li>1 &le; D, W, y &le; 100<\/li>\r\n<\/ul>\r\n","subtask2":"<ul>\r\n\t<li>1 &le; R, C &le; 20<\/li>\r\n\t<li>1 &le; D, W, y &le; 1,000,000<\/li>\r\n<\/ul>\r\n","subtask3":"<ul>\r\n\t<li>1 &le; R, C &le; 50<\/li>\r\n\t<li>1 &le; D, W, y &le;&nbsp;1,000,000,000<\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>In this case, choosing Z = 10 leads to building two skyscrapers (at 10*10 = 100 dollars) and constructing two parks to cover the remaining four city blocks (at 120*2 = 240 dollars), totalling 340 dollars. This is optimal (there are many values of Z that achieces this). On the other hand, if you choose Z = 0 then the total cost is 360 dollars; if you choose Z = 40, the total cost is 400 dollars. &nbsp;Note that if you choose Z = 20, you will be building four skyscrapers but you will not be able to build a park on the remaining two blocks in a legitimate way, as the following image demonstrates.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/1ee5c4e1-6db0-47f9-a95b-028a5f185134\/-\/preview\/\" style=\"width: 148px; height: 100px;\" \/><\/p>\r\n"}]

출처

  • 문제를 만든 사람: haden