시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 1024 MB163383627.692%

문제

부 뎅클렉은 메기 양어장을 가지고 있다. 양어장은 $N \times N$ 격자칸 모양이다. 격자의 칸들은 같은 크기의 정사각형이다. 격자의 열들은 서쪽에서 동쪽으로 $0$부터 $N - 1$까지 번호가 붙어 있고, 행들은 남쪽에서 북쪽으로 $0$부터 $N - 1$까지 번호가 붙어있다. 열 $c$, 행 $r$에 ($0 \le c \le N - 1$, $0 \le r \le N - 1$) 있는 칸을 칸 $(c, r)$로 부른다.

양어장에는 $M$ 마리의 메기가 있다. 메기들은 $0$부터 $M - 1$까지 번호가 붙어 있고, 모두 다른 칸에 있다. 각각의 $i$에 대해 ($0 \le i \le M - 1$) 메기 $i$는 칸 $(X[i], Y[i])$에 있고, 그 무게는 $W[i]$그램이다.

부 뎅클렉은 메기를 잡기 위해 낚시터를 지으려고 한다. 열 $c$에 있는 길이 $k$인 낚시터는 ($0 \le c \le N - 1$, $1 \le k \le N$), 열 $c$의 행 $0$부터 행$k - 1$까지를 덮는 직사각형이다. 즉, 낚시터는 칸들 $(c, 0), (c, 1), \ldots, (c, k - 1)$를 덮는다. 각 열에 대해서 부 뎅클렉은 특정한 길이의 낚시터를 짓거나, 낚시터를 전혀 짓지 않는 것 중 선택을 할 수 있다.

메기 $i$를 ($0 \le i \le M - 1$) 잡기 위해서는 메기 $i$의 위치의 서쪽이나 동쪽에 인접한 칸을 낚시터가 덮어야 하며, 메기 $i$의 위치는 낚시터가 덮지 않아야 한다. 다시 말하면,

  • 칸들 $(X[i] - 1, Y[i])$와 $(X[i] + 1, Y[i])$ 중 적어도 하나가 낚시터에 덮이고,
  • 칸 $(X[i], Y[i])$는 낚시터에 덮이지 않아야 한다.

예를 들어, $N = 5$인 양어장에 $M = 4$마리의 메기가 있다고 하자.

  • 메기 $0$의 위치는 칸 $(0, 2)$이고 그 무게는 $5$그램이다.
  • 메기 $1$의 위치는 칸 $(1, 1)$이고 그 무게는 $2$그램이다.
  • 메기 $2$의 위치는 칸 $(4, 4)$이고 그 무게는 $1$그램이다.
  • 메기 $3$의 위치는 칸 $(3, 3)$이고 그 무게는 $3$그램이다.

부 뎅클렉이 낚시터를 지을 수 있는 방법 중 하나는 아래와 같다.

낚시터 짓기 전 낚시터 지은 후

칸에 표시된 자연수는 그 칸에 있는 메기의 무게이다. 색칠된 칸들이 낚시터에 덮인 곳이다. 이 경우 잡을 수 있는 메기는 메기 $0$(칸 $(0, 2)$에 위치)과 메기 $3$(칸 $(3, 3)$에 위치)이다. 메기 $1$(칸 $(1, 1)$에 위치)는 그 칸이 낚시터에 덮여 있어 잡을 수 없다. 메기 $2$(칸 $(4, 4)$에 위치)는 서쪽이나 동쪽에 인접한 칸이 낚시터로 덮인 것이 없어 잡을 수 없다.

부 뎅클렉은 잡을 수 있는 메기의 무게의 합이 가장 크도록 낚시터를 짓고 싶다. 잡을 수 있는 메기의 최대 무게 합을 계산하는 프로그램을 작성하라.

구현

당신은 다음 함수를 구현해야 한다:

int64 max_weights(int N, int M, int[] X, int[] Y, int[] W)
  • $N$: 양식장의 크기.
  • $M$: 메기의 마리 수.
  • $X$, $Y$: 메기의 위치를 표현한 크기 $M$인 배열들.
  • $W$: 메기의 무게를 표현한 크기 $M$인 배열.
  • 이 함수는 부 뎅클렉이 낚시터를 지어서 잡을 수 있는 최대의 메기 무게 합을 리턴해야 한다.
  • 이 함수는 정확히 한번 호출된다.

예제

다음 호출을 생각하자:

max_weights(5, 4, [0, 1, 4, 3], [2, 1, 4, 3], [5, 2, 1, 3])

이 예제는 위의 문제 설명에 있는 것과 같다.

문제 설명에 있는 것과 같이 낚시터를 지으면, 부 뎅클렉은 메기 $0$과 $3$을 잡을 수 있고, 무게의 합은 $5 + 3 = 8$ 그램이다. 이 방법이 최선이며 함수는 $8$을 리턴해야 한다.

제한

  • $2 \le N \le 100\,000$
  • $1 \le M \le 300\,000$
  • $0 \le X[i] \le N - 1$, $0 \le Y[i] \le N - 1$ ($0 \le i \le M - 1$)
  • $1 \le W[i] \le 10^9$ ($0 \le i \le M - 1$)
  • 메기들의 위치는 모두 다르다. 즉, $X[i] \neq X[j]$ 혹은 $Y[i] \neq Y[j]$ ($0 \le i \lt j \le M - 1$).

서브태스크

번호배점제한
13

$X[i]$가 짝수 ($0 \le i \le M - 1$)

26

$X[i] \le 1$ ($0 \le i \le M - 1$)

39

$Y[i] = 0$ ($0 \le i \le M - 1$)

414

$N \le 300$, $Y[i] \le 8$ ($0 \le i \le M - 1$)

521

$N \le 300$

617

$N \le 3000$

714

각 열에는 최대 $2$ 마리의 메기가 있다.

816

추가적인 제한이 없다.

[{"problem_id":"25438","problem_lang":"0","title":"\uba54\uae30 \ub18d\uc7a5","description":"<p>\ubd80 \ub385\ud074\ub809\uc740 \uba54\uae30 \uc591\uc5b4\uc7a5\uc744 \uac00\uc9c0\uace0 \uc788\ub2e4. \uc591\uc5b4\uc7a5\uc740 $N \\times N$ \uaca9\uc790\uce78 \ubaa8\uc591\uc774\ub2e4. \uaca9\uc790\uc758 \uce78\ub4e4\uc740 \uac19\uc740 \ud06c\uae30\uc758 \uc815\uc0ac\uac01\ud615\uc774\ub2e4. \uaca9\uc790\uc758 \uc5f4\ub4e4\uc740 \uc11c\ucabd\uc5d0\uc11c \ub3d9\ucabd\uc73c\ub85c $0$\ubd80\ud130 $N - 1$\uae4c\uc9c0 \ubc88\ud638\uac00 \ubd99\uc5b4 \uc788\uace0, \ud589\ub4e4\uc740 \ub0a8\ucabd\uc5d0\uc11c \ubd81\ucabd\uc73c\ub85c $0$\ubd80\ud130 $N - 1$\uae4c\uc9c0 \ubc88\ud638\uac00 \ubd99\uc5b4\uc788\ub2e4. \uc5f4 $c$, \ud589 $r$\uc5d0 ($0 \\le c \\le N - 1$, $0 \\le r \\le N - 1$) \uc788\ub294 \uce78\uc744 \uce78 $(c, r)$\ub85c \ubd80\ub978\ub2e4.<\/p>\r\n\r\n<p>\uc591\uc5b4\uc7a5\uc5d0\ub294 $M$ \ub9c8\ub9ac\uc758 \uba54\uae30\uac00 \uc788\ub2e4. \uba54\uae30\ub4e4\uc740 $0$\ubd80\ud130 $M - 1$\uae4c\uc9c0 \ubc88\ud638\uac00 \ubd99\uc5b4 \uc788\uace0, \ubaa8\ub450 <strong>\ub2e4\ub978<\/strong> \uce78\uc5d0 \uc788\ub2e4. \uac01\uac01\uc758 $i$\uc5d0 \ub300\ud574 ($0 \\le i \\le M - 1$) \uba54\uae30 $i$\ub294 \uce78 $(X[i], Y[i])$\uc5d0 \uc788\uace0, \uadf8 \ubb34\uac8c\ub294 $W[i]$\uadf8\ub7a8\uc774\ub2e4.<\/p>\r\n\r\n<p>\ubd80 \ub385\ud074\ub809\uc740 \uba54\uae30\ub97c \uc7a1\uae30 \uc704\ud574 \ub09a\uc2dc\ud130\ub97c \uc9c0\uc73c\ub824\uace0 \ud55c\ub2e4. \uc5f4 $c$\uc5d0 \uc788\ub294 \uae38\uc774 $k$\uc778 \ub09a\uc2dc\ud130\ub294 ($0 \\le c \\le N - 1$, $1 \\le k \\le N$), \uc5f4 $c$\uc758 \ud589 $0$\ubd80\ud130 \ud589$k - 1$\uae4c\uc9c0\ub97c \ub36e\ub294 \uc9c1\uc0ac\uac01\ud615\uc774\ub2e4. \uc989, \ub09a\uc2dc\ud130\ub294 \uce78\ub4e4 $(c, 0), (c, 1), \\ldots, (c, k - 1)$\ub97c \ub36e\ub294\ub2e4. \uac01 \uc5f4\uc5d0 \ub300\ud574\uc11c \ubd80 \ub385\ud074\ub809\uc740 \ud2b9\uc815\ud55c \uae38\uc774\uc758 \ub09a\uc2dc\ud130\ub97c \uc9d3\uac70\ub098, \ub09a\uc2dc\ud130\ub97c \uc804\ud600 \uc9d3\uc9c0 \uc54a\ub294 \uac83 \uc911 \uc120\ud0dd\uc744 \ud560 \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<p>\uba54\uae30 $i$\ub97c ($0 \\le i \\le M - 1$) \uc7a1\uae30 \uc704\ud574\uc11c\ub294 \uba54\uae30 $i$\uc758 \uc704\uce58\uc758 \uc11c\ucabd\uc774\ub098 \ub3d9\ucabd\uc5d0 \uc778\uc811\ud55c \uce78\uc744 \ub09a\uc2dc\ud130\uac00 \ub36e\uc5b4\uc57c \ud558\uba70, \uba54\uae30 $i$\uc758 \uc704\uce58\ub294 \ub09a\uc2dc\ud130\uac00 \ub36e\uc9c0 \uc54a\uc544\uc57c \ud55c\ub2e4. \ub2e4\uc2dc \ub9d0\ud558\uba74,<\/p>\r\n\r\n<ul>\r\n\t<li>\uce78\ub4e4 $(X[i] - 1, Y[i])$\uc640 $(X[i] + 1, Y[i])$ \uc911 <strong>\uc801\uc5b4\ub3c4 \ud558\ub098<\/strong>\uac00 \ub09a\uc2dc\ud130\uc5d0 \ub36e\uc774\uace0,<\/li>\r\n\t<li>\uce78 $(X[i], Y[i])$\ub294 \ub09a\uc2dc\ud130\uc5d0 \ub36e\uc774\uc9c0 \uc54a\uc544\uc57c \ud55c\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4, $N = 5$\uc778 \uc591\uc5b4\uc7a5\uc5d0 $M = 4$\ub9c8\ub9ac\uc758 \uba54\uae30\uac00 \uc788\ub2e4\uace0 \ud558\uc790.<\/p>\r\n\r\n<ul>\r\n\t<li>\uba54\uae30 $0$\uc758 \uc704\uce58\ub294 \uce78 $(0, 2)$\uc774\uace0 \uadf8 \ubb34\uac8c\ub294 $5$\uadf8\ub7a8\uc774\ub2e4.<\/li>\r\n\t<li>\uba54\uae30 $1$\uc758 \uc704\uce58\ub294 \uce78 $(1, 1)$\uc774\uace0 \uadf8 \ubb34\uac8c\ub294 $2$\uadf8\ub7a8\uc774\ub2e4.<\/li>\r\n\t<li>\uba54\uae30 $2$\uc758 \uc704\uce58\ub294 \uce78 $(4, 4)$\uc774\uace0 \uadf8 \ubb34\uac8c\ub294 $1$\uadf8\ub7a8\uc774\ub2e4.<\/li>\r\n\t<li>\uba54\uae30 $3$\uc758 \uc704\uce58\ub294 \uce78 $(3, 3)$\uc774\uace0 \uadf8 \ubb34\uac8c\ub294 $3$\uadf8\ub7a8\uc774\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ubd80 \ub385\ud074\ub809\uc774 \ub09a\uc2dc\ud130\ub97c \uc9c0\uc744 \uc218 \uc788\ub294 \ubc29\ubc95 \uc911 \ud558\ub098\ub294 \uc544\ub798\uc640 \uac19\ub2e4.<\/p>\r\n\r\n<table class=\"table table-bordered td-center th-center\">\r\n\t<thead>\r\n\t\t<tr>\r\n\t\t\t<th>\ub09a\uc2dc\ud130 \uc9d3\uae30 \uc804<\/th>\r\n\t\t\t<th>\ub09a\uc2dc\ud130 \uc9c0\uc740 \ud6c4<\/th>\r\n\t\t<\/tr>\r\n\t<\/thead>\r\n\t<tbody>\r\n\t\t<tr>\r\n\t\t\t<td><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/33a966fe-3a12-4a09-94a9-37d960539927\/-\/crop\/561x576\/0,0\/-\/preview\/\" style=\"width: 280px; height: 287px;\" \/><\/td>\r\n\t\t\t<td><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/33a966fe-3a12-4a09-94a9-37d960539927\/-\/crop\/561x576\/629,0\/-\/preview\/\" style=\"width: 280px; height: 287px;\" \/><\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n\r\n<p>\uce78\uc5d0 \ud45c\uc2dc\ub41c \uc790\uc5f0\uc218\ub294 \uadf8 \uce78\uc5d0 \uc788\ub294 \uba54\uae30\uc758 \ubb34\uac8c\uc774\ub2e4. \uc0c9\uce60\ub41c \uce78\ub4e4\uc774 \ub09a\uc2dc\ud130\uc5d0 \ub36e\uc778 \uacf3\uc774\ub2e4. \uc774 \uacbd\uc6b0 \uc7a1\uc744 \uc218 \uc788\ub294 \uba54\uae30\ub294 \uba54\uae30 $0$(\uce78 $(0, 2)$\uc5d0 \uc704\uce58)\uacfc \uba54\uae30 $3$(\uce78 $(3, 3)$\uc5d0 \uc704\uce58)\uc774\ub2e4. \uba54\uae30 $1$(\uce78 $(1, 1)$\uc5d0 \uc704\uce58)\ub294 \uadf8 \uce78\uc774 \ub09a\uc2dc\ud130\uc5d0 \ub36e\uc5ec \uc788\uc5b4 \uc7a1\uc744 \uc218 \uc5c6\ub2e4. \uba54\uae30 $2$(\uce78 $(4, 4)$\uc5d0 \uc704\uce58)\ub294 \uc11c\ucabd\uc774\ub098 \ub3d9\ucabd\uc5d0 \uc778\uc811\ud55c \uce78\uc774 \ub09a\uc2dc\ud130\ub85c \ub36e\uc778 \uac83\uc774 \uc5c6\uc5b4 \uc7a1\uc744 \uc218 \uc5c6\ub2e4.<\/p>\r\n\r\n<p>\ubd80 \ub385\ud074\ub809\uc740 \uc7a1\uc744 \uc218 \uc788\ub294 \uba54\uae30\uc758 \ubb34\uac8c\uc758 \ud569\uc774 \uac00\uc7a5 \ud06c\ub3c4\ub85d \ub09a\uc2dc\ud130\ub97c \uc9d3\uace0 \uc2f6\ub2e4. \uc7a1\uc744 \uc218 \uc788\ub294 \uba54\uae30\uc758 \ucd5c\ub300 \ubb34\uac8c \ud569\uc744 \uacc4\uc0b0\ud558\ub294 \ud504\ub85c\uadf8\ub7a8\uc744 \uc791\uc131\ud558\ub77c.<\/p>\r\n","input":"","output":"","hint":"","original":"0","html_title":"0","problem_lang_tcode":"Korean","limit":"<ul>\r\n\t<li>$2 \\le N \\le 100\\,000$<\/li>\r\n\t<li>$1 \\le M \\le 300\\,000$<\/li>\r\n\t<li>$0 \\le X[i] \\le N - 1$, $0 \\le Y[i] \\le N - 1$ ($0 \\le i \\le M - 1$)<\/li>\r\n\t<li>$1 \\le W[i] \\le 10^9$ ($0 \\le i \\le M - 1$)<\/li>\r\n\t<li>\uba54\uae30\ub4e4\uc758 \uc704\uce58\ub294 \ubaa8\ub450 \ub2e4\ub974\ub2e4. \uc989, $X[i] \\neq X[j]$ \ud639\uc740 $Y[i] \\neq Y[j]$ ($0 \\le i \\lt j \\le M - 1$).<\/li>\r\n<\/ul>\r\n","subtask1":"<p>$X[i]$\uac00 \uc9dd\uc218 ($0 \\le i \\le M - 1$)<\/p>\r\n","subtask2":"<p>$X[i] \\le 1$ ($0 \\le i \\le M - 1$)<\/p>\r\n","subtask3":"<p>$Y[i] = 0$ ($0 \\le i \\le M - 1$)<\/p>\r\n","subtask4":"<p>$N \\le 300$, $Y[i] \\le 8$ ($0 \\le i \\le M - 1$)<\/p>\r\n","subtask5":"<p>$N \\le 300$<\/p>\r\n","subtask6":"<p>$N \\le 3000$<\/p>\r\n","subtask7":"<p>\uac01 \uc5f4\uc5d0\ub294 \ucd5c\ub300 $2$ \ub9c8\ub9ac\uc758 \uba54\uae30\uac00 \uc788\ub2e4.<\/p>\r\n","subtask8":"<p>\ucd94\uac00\uc801\uc778 \uc81c\ud55c\uc774 \uc5c6\ub2e4.<\/p>\r\n","custom_implementation":"<p>\ub2f9\uc2e0\uc740 \ub2e4\uc74c \ud568\uc218\ub97c \uad6c\ud604\ud574\uc57c \ud55c\ub2e4:<\/p>\r\n\r\n<pre>\r\n<code>int64 max_weights(int N, int M, int[] X, int[] Y, int[] W)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$N$: \uc591\uc2dd\uc7a5\uc758 \ud06c\uae30.<\/li>\r\n\t<li>$M$: \uba54\uae30\uc758 \ub9c8\ub9ac \uc218.<\/li>\r\n\t<li>$X$, $Y$: \uba54\uae30\uc758 \uc704\uce58\ub97c \ud45c\ud604\ud55c \ud06c\uae30 $M$\uc778 \ubc30\uc5f4\ub4e4.<\/li>\r\n\t<li>$W$: \uba54\uae30\uc758 \ubb34\uac8c\ub97c \ud45c\ud604\ud55c \ud06c\uae30 $M$\uc778 \ubc30\uc5f4.<\/li>\r\n\t<li>\uc774 \ud568\uc218\ub294 \ubd80 \ub385\ud074\ub809\uc774 \ub09a\uc2dc\ud130\ub97c \uc9c0\uc5b4\uc11c \uc7a1\uc744 \uc218 \uc788\ub294 \ucd5c\ub300\uc758 \uba54\uae30 \ubb34\uac8c \ud569\uc744 \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4.<\/li>\r\n\t<li>\uc774 \ud568\uc218\ub294 \uc815\ud655\ud788 \ud55c\ubc88 \ud638\ucd9c\ub41c\ub2e4.<\/li>\r\n<\/ul>\r\n","custom_example":"<p>\ub2e4\uc74c \ud638\ucd9c\uc744 \uc0dd\uac01\ud558\uc790:<\/p>\r\n\r\n<pre>\r\n<code>max_weights(5, 4, [0, 1, 4, 3], [2, 1, 4, 3], [5, 2, 1, 3])\r\n<\/code><\/pre>\r\n\r\n<p>\uc774 \uc608\uc81c\ub294 \uc704\uc758 \ubb38\uc81c \uc124\uba85\uc5d0 \uc788\ub294 \uac83\uacfc \uac19\ub2e4.<\/p>\r\n\r\n<p>\ubb38\uc81c \uc124\uba85\uc5d0 \uc788\ub294 \uac83\uacfc \uac19\uc774 \ub09a\uc2dc\ud130\ub97c \uc9c0\uc73c\uba74, \ubd80 \ub385\ud074\ub809\uc740 \uba54\uae30 $0$\uacfc $3$\uc744 \uc7a1\uc744 \uc218 \uc788\uace0, \ubb34\uac8c\uc758 \ud569\uc740 $5 + 3 = 8$ \uadf8\ub7a8\uc774\ub2e4. \uc774 \ubc29\ubc95\uc774 \ucd5c\uc120\uc774\uba70 \ud568\uc218\ub294 $8$\uc744 \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n","custom_samplegrader":"<p>\uc0d8\ud50c \uadf8\ub808\uc774\ub354\ub294 \ub2e4\uc74c \ud615\uc2dd\uc73c\ub85c \uc785\ub825\uc744 \uc77d\ub294\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1$: $N \\, M$<\/li>\r\n\t<li>line $2 + i$ ($0 \\le i \\le M - 1$): $X[i] \\, Y[i] \\, W[i]$<\/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$: <code>max_weights<\/code>\uc758 \ub9ac\ud134 \uac12<\/li>\r\n<\/ul>\r\n","custom_attachment":"<ul>\r\n\t<li><a href=\"https:\/\/upload.acmicpc.net\/09616177-4a0b-4ec5-a985-37f66a596b5a\/\">fish.zip<\/a><\/li>\r\n<\/ul>\r\n"},{"problem_id":"25438","problem_lang":"1","title":"Catfish Farm","description":"<p>Bu Dengklek owns a catfish farm. The catfish farm is a pond consisting of a $N \\times N$ grid of cells. Each cell is a square of the same size. The columns of the grid are numbered from $0$ to $N - 1$ from west to east and the rows are numbered from $0$ to $N - 1$ from south to north. We refer to the cell located at column $c$ and row $r$ of the grid ($0 \\le c \\le N - 1$, $0 \\le r \\le N - 1$) as cell $(c, r)$.<\/p>\r\n\r\n<p>In the pond, there are $M$ catfish, numbered from $0$ to $M - 1$, located at&nbsp;<strong>distinct<\/strong>&nbsp;cells. For each $i$ such that $0 \\le i \\le M - 1$, catfish $i$ is located at cell $(X[i], Y[i])$, and weighs $W[i]$ grams.<\/p>\r\n\r\n<p>Bu Dengklek wants to build some piers to catch the catfish. A pier in column $c$ of length $k$ (for any $0 \\le c \\le N - 1$ and $1 \\le k \\le N$) is a rectangle extending from row $0$ to row $k - 1$, covering cells $(c, 0), (c, 1), \\ldots, (c, k - 1)$. For each column, Bu Dengklek can choose either to build a pier of some length of her choice or to not build a pier.<\/p>\r\n\r\n<p>Catfish $i$ (for each $i$ such that $0 \\le i \\le M - 1$) can be caught if there is a pier directly to the west or east of it, and there is no pier covering its cell; that is, if<\/p>\r\n\r\n<ul>\r\n\t<li><strong>at least one<\/strong>&nbsp;of the cells $(X[i] - 1, Y[i])$ or $(X[i] + 1, Y[i])$ is covered by a pier, and<\/li>\r\n\t<li>there is no pier covering cell $(X[i], Y[i])$.<\/li>\r\n<\/ul>\r\n\r\n<p>For example, consider a pond of size $N = 5$ with $M = 4$ catfish:<\/p>\r\n\r\n<ul>\r\n\t<li>Catfish $0$ is located at cell $(0, 2)$ and weighs $5$ grams.<\/li>\r\n\t<li>Catfish $1$ is located at cell $(1, 1)$ and weighs $2$ grams.<\/li>\r\n\t<li>Catfish $2$ is located at cell $(4, 4)$ and weighs $1$ gram.<\/li>\r\n\t<li>Catfish $3$ is located at cell $(3, 3)$ and weighs $3$ grams.<\/li>\r\n<\/ul>\r\n\r\n<p>One way Bu Dengklek can build the piers is as follows:<\/p>\r\n\r\n<table class=\"table table-bordered td-center th-center\">\r\n\t<thead>\r\n\t\t<tr>\r\n\t\t\t<th>Before the piers are built<\/th>\r\n\t\t\t<th>After the piers are built<\/th>\r\n\t\t<\/tr>\r\n\t<\/thead>\r\n\t<tbody>\r\n\t\t<tr>\r\n\t\t\t<td><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/33a966fe-3a12-4a09-94a9-37d960539927\/-\/crop\/561x576\/0,0\/-\/preview\/\" style=\"width: 280px; height: 287px;\" \/><\/td>\r\n\t\t\t<td><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/33a966fe-3a12-4a09-94a9-37d960539927\/-\/crop\/561x576\/629,0\/-\/preview\/\" style=\"width: 280px; height: 287px;\" \/><\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n\r\n<p>The number at a cell denotes the weight of the catfish located at the cell. The shaded cells are covered by piers. In this case, catfish $0$ (at cell $(0, 2)$) and catfish $3$ (at cell $(3, 3)$) can be caught. Catfish $1$ (at cell $(1, 1)$) cannot be caught, as there is a pier covering its location, while catfish $2$ (at cell $(4, 4)$) can not be caught as there is no pier directly to the west nor east of it.<\/p>\r\n\r\n<p>Bu Dengklek would like to build piers so that the total weight of catfish she can catch is as large as possible. Your task is to find the maximum total weight of catfish that Bu Dengklek can catch after building piers.<\/p>\r\n","input":"","output":"","hint":"","original":"1","html_title":"0","problem_lang_tcode":"English","limit":"<ul>\r\n\t<li>$2 \\le N \\le 100\\,000$<\/li>\r\n\t<li>$1 \\le M \\le 300\\,000$<\/li>\r\n\t<li>$0 \\le X[i] \\le N - 1$, $0 \\le Y[i] \\le N - 1$ (for each $i$ such that $0 \\le i \\le M - 1$)<\/li>\r\n\t<li>$1 \\le W[i] \\le 10^9$ (for each $i$ such that $0 \\le i \\le M - 1$)<\/li>\r\n\t<li>No two catfish share the same cell. In other words, $X[i] \\neq X[j]$ or $Y[i] \\neq Y[j]$ (for each $i$ and $j$ such that $0 \\le i \\lt j \\le M - 1$).<\/li>\r\n<\/ul>\r\n","subtask1":"<p>$X[i]$ is even (for each $i$ such that $0 \\le i \\le M - 1$)<\/p>\r\n","subtask2":"<p>$X[i] \\le 1$ (for each $i$ such that $0 \\le i \\le M - 1$)<\/p>\r\n","subtask3":"<p>$Y[i] = 0$ (for each $i$ such that $0 \\le i \\le M - 1$)<\/p>\r\n","subtask4":"<p>$N \\le 300$, $Y[i] \\le 8$ (for each $i$ such that $0 \\le i \\le M - 1$)<\/p>\r\n","subtask5":"<p>$N \\le 300$<\/p>\r\n","subtask6":"<p>$N \\le 3000$<\/p>\r\n","subtask7":"<p>There are at most $2$ catfish in each column.<\/p>\r\n","subtask8":"<p>No additional constraints.<\/p>\r\n","custom_implementation":"<p>You should implement the following procedure:<\/p>\r\n\r\n<pre>\r\n<code>int64 max_weights(int N, int M, int[] X, int[] Y, int[] W)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$N$: the size of the pond.<\/li>\r\n\t<li>$M$: the number of catfish.<\/li>\r\n\t<li>$X$, $Y$: arrays of length $M$ describing catfish locations.<\/li>\r\n\t<li>$W$: array of length $M$ describing catfish weights.<\/li>\r\n\t<li>This procedure should return an integer representing the maximum total weight of catfish that Bu Dengklek can catch after building piers.<\/li>\r\n\t<li>This procedure is called exactly once.<\/li>\r\n<\/ul>\r\n","custom_example":"<p>Consider the following call:<\/p>\r\n\r\n<pre>\r\n<code>max_weights(5, 4, [0, 1, 4, 3], [2, 1, 4, 3], [5, 2, 1, 3])\r\n<\/code><\/pre>\r\n\r\n<p>This example is illustrated in the task description above.<\/p>\r\n\r\n<p>After building piers as described, Bu Dengklek can catch catfish $0$ and $3$, whose total weight is $5 + 3 = 8$ grams. As there is no way to build piers to catch catfish with a total weight of more than $8$ grams, the procedure should return $8$.<\/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 \\, M$<\/li>\r\n\t<li>line $2 + i$ ($0 \\le i \\le M - 1$): $X[i] \\, Y[i] \\, W[i]$<\/li>\r\n<\/ul>\r\n\r\n<p>The sample grader prints your answer in the following format:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1$: the return value of <code>max_weights<\/code><\/li>\r\n<\/ul>\r\n","custom_attachment":"<ul>\r\n\t<li><a href=\"https:\/\/upload.acmicpc.net\/09616177-4a0b-4ec5-a985-37f66a596b5a\/\">fish.zip<\/a><\/li>\r\n<\/ul>\r\n"}]

샘플 그레이더

샘플 그레이더는 다음 형식으로 입력을 읽는다:

  • line $1$: $N \, M$
  • line $2 + i$ ($0 \le i \le M - 1$): $X[i] \, Y[i] \, W[i]$

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

  • line $1$: max_weights의 리턴 값

첨부

출처

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

  • 문제를 만든 사람: Lim Rui Yuan

제출할 수 있는 언어

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

채점 및 기타 정보

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