시간 제한메모리 제한제출정답맞힌 사람정답 비율
3 초 512 MB417927029.289%

문제

당신은 친구를 도와 새로운 카풀 앱을 개발해야 한다. 그 중 운전자와 승객을 매칭 시켜주는 알고리즘을 당신이 개발해야 한다. 현재 이 앱은 베타 버전이기 때문에 동-서로 길게 늘어진 고속도로 위에 위치한 지역에서만 서비스를 하고 있으며 아래와 같은 제한이 있다. 

  • 모든 운전자와 승객은 가장 동쪽에 위치한 “출발지" 도시에서 출발한다.
  • 총 N명의 승객이 있으며, i번째 승객은 출발지에서 서쪽으로 xi 미터 떨어진 곳에 위치한 목적지에 가고 싶어한다 (0 < xi).
  • 총 M명의 운전자가 있으며, j번째 운전자는 출발지에서 서쪽으로 yj 미터 이상 zj 미터 이하 떨어진 곳 사이에 가고 싶어하는 승객을 최대 한 명 태워줄 의향이 있다 (0 < yj ≤ zj). 

당신은 이 조건들을 만족하면서 최대한 많은 승객-운전자를 매칭시키는 알고리즘을 작성해야 한다.

예를 들어, 3명의 승객과 3명의 운전자가 있을 때, x, y, z 값이 아래와 같다고 하자.

  • x = [10, 20, 30]
  • y = [8, 2, 25]
  • z = [8, 18, 35]

이 경우 승객 1, 2, 3은 각각 정확 10미터, 20미터, 30미터 떨어진 곳으로 가고 싶어하며, 운전자 1은 정확히 8미터 떨어진 곳에 가려는 승객을 태울 의향이 있고,  운전자 2는 2미터 이상 18미터 이하 떨어진 곳에 가려는 승객을 태울 의향이 있고, 운전자 3은 25미터 이상 35미터 이하 떨어진 곳에 가려는 승객을 태울 의향이 있다.

이 경우, 승객1-운전자2, 승객3-운전자3을 매칭시켜주면 총 두 쌍을 매칭시킬 수 있고 이보다 많은 수의 승객-운전자를 매칭 시킬 수 있는 방법은 없다.

입력으로 N, M, 그리고 x, y, z 값들을 입력 받아 최대한 많은 승객-운전자 쌍을 매칭시키면 몇 쌍을 매칭 시킬 수 있는지 계산하는 프로그램을 작성하시오.

입력

첫 줄에 테스트 케이스의 수 T가 주어진다 (1 ≤ T ≤ 10).

각 테스트 케이스의 첫 줄에는 N, M 이 주어진다.

그 다음 줄에 xi 가 공백으로 구분되어 주어진다 (1 ≤ xi ≤ 1,000,000,000).

다음 M줄에 걸쳐 각 줄에 yj 와 zj 가 공백으로 구분되어 주어진다 (1 ≤ yj ≤ zj ≤ 1,000,000,000).

출력

각 테스트 케이스에 대해, 최대한 많은 승객-운전자를 매칭 시켰을 때 몇 쌍을 매칭시킬 수 있는지 출력한다.

서브태스크 1 (7점)

  • 1 ≤ N, M ≤ 100

서브태스크 2 (13점)

  • 1 ≤ N, M ≤ 100,000

예제 입력 1

3
3 3
10 20 30
8 8
2 18
25 35
4 4
2 3 4 5
1 4
2 4
3 5
3 4
3 3
1 2 3
10 20
30 40
50 60

예제 출력 1

2
4
0
[{"problem_id":"17280","problem_lang":"0","title":"\uce74\ud480 \ub9e4\uce6d","description":"<p>\ub2f9\uc2e0\uc740 \uce5c\uad6c\ub97c \ub3c4\uc640 \uc0c8\ub85c\uc6b4 \uce74\ud480 \uc571\uc744 \uac1c\ubc1c\ud574\uc57c \ud55c\ub2e4. \uadf8 \uc911 \uc6b4\uc804\uc790\uc640 \uc2b9\uac1d\uc744 \ub9e4\uce6d \uc2dc\ucf1c\uc8fc\ub294 \uc54c\uace0\ub9ac\uc998\uc744 \ub2f9\uc2e0\uc774 \uac1c\ubc1c\ud574\uc57c \ud55c\ub2e4. \ud604\uc7ac \uc774 \uc571\uc740 \ubca0\ud0c0 \ubc84\uc804\uc774\uae30 \ub54c\ubb38\uc5d0 \ub3d9-\uc11c\ub85c \uae38\uac8c \ub298\uc5b4\uc9c4 \uace0\uc18d\ub3c4\ub85c \uc704\uc5d0 \uc704\uce58\ud55c \uc9c0\uc5ed\uc5d0\uc11c\ub9cc \uc11c\ube44\uc2a4\ub97c \ud558\uace0 \uc788\uc73c\uba70 \uc544\ub798\uc640 \uac19\uc740 \uc81c\ud55c\uc774 \uc788\ub2e4.&nbsp;<\/p>\r\n\r\n<ul>\r\n\t<li>\ubaa8\ub4e0 \uc6b4\uc804\uc790\uc640 \uc2b9\uac1d\uc740 \uac00\uc7a5 \ub3d9\ucabd\uc5d0 \uc704\uce58\ud55c &ldquo;\ucd9c\ubc1c\uc9c0&quot; \ub3c4\uc2dc\uc5d0\uc11c \ucd9c\ubc1c\ud55c\ub2e4.<\/li>\r\n\t<li>\ucd1d N\uba85\uc758 \uc2b9\uac1d\uc774 \uc788\uc73c\uba70, i\ubc88\uc9f8 \uc2b9\uac1d\uc740 \ucd9c\ubc1c\uc9c0\uc5d0\uc11c \uc11c\ucabd\uc73c\ub85c x<sub>i<\/sub> \ubbf8\ud130 \ub5a8\uc5b4\uc9c4 \uacf3\uc5d0 \uc704\uce58\ud55c \ubaa9\uc801\uc9c0\uc5d0 \uac00\uace0 \uc2f6\uc5b4\ud55c\ub2e4 (0 &lt; x<sub>i<\/sub>).<\/li>\r\n\t<li>\ucd1d M\uba85\uc758 \uc6b4\uc804\uc790\uac00 \uc788\uc73c\uba70, j\ubc88\uc9f8 \uc6b4\uc804\uc790\ub294 \ucd9c\ubc1c\uc9c0\uc5d0\uc11c \uc11c\ucabd\uc73c\ub85c y<sub>j<\/sub> \ubbf8\ud130 \uc774\uc0c1 z<sub>j<\/sub> \ubbf8\ud130 \uc774\ud558 \ub5a8\uc5b4\uc9c4 \uacf3 \uc0ac\uc774\uc5d0 \uac00\uace0 \uc2f6\uc5b4\ud558\ub294 \uc2b9\uac1d\uc744 \ucd5c\ub300 \ud55c \uba85 \ud0dc\uc6cc\uc904 \uc758\ud5a5\uc774 \uc788\ub2e4 (0 &lt; y<sub>j<\/sub>&nbsp;&le;&nbsp;z<sub>j<\/sub>).&nbsp;<\/li>\r\n<\/ul>\r\n\r\n<p>\ub2f9\uc2e0\uc740 \uc774 \uc870\uac74\ub4e4\uc744 \ub9cc\uc871\ud558\uba74\uc11c \ucd5c\ub300\ud55c \ub9ce\uc740 \uc2b9\uac1d-\uc6b4\uc804\uc790\ub97c \ub9e4\uce6d\uc2dc\ud0a4\ub294 \uc54c\uace0\ub9ac\uc998\uc744 \uc791\uc131\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4, 3\uba85\uc758 \uc2b9\uac1d\uacfc 3\uba85\uc758 \uc6b4\uc804\uc790\uac00 \uc788\uc744 \ub54c, x, y, z \uac12\uc774 \uc544\ub798\uc640 \uac19\ub2e4\uace0 \ud558\uc790.<\/p>\r\n\r\n<ul>\r\n\t<li>x = [10, 20, 30]<\/li>\r\n\t<li>y = [8, 2, 25]<\/li>\r\n\t<li>z = [8, 18, 35]<\/li>\r\n<\/ul>\r\n\r\n<p>\uc774 \uacbd\uc6b0 \uc2b9\uac1d 1, 2, 3\uc740 \uac01\uac01 \uc815\ud655 10\ubbf8\ud130, 20\ubbf8\ud130, 30\ubbf8\ud130 \ub5a8\uc5b4\uc9c4 \uacf3\uc73c\ub85c \uac00\uace0 \uc2f6\uc5b4\ud558\uba70, \uc6b4\uc804\uc790 1\uc740 \uc815\ud655\ud788 8\ubbf8\ud130 \ub5a8\uc5b4\uc9c4 \uacf3\uc5d0 \uac00\ub824\ub294 \uc2b9\uac1d\uc744 \ud0dc\uc6b8 \uc758\ud5a5\uc774 \uc788\uace0,&nbsp; \uc6b4\uc804\uc790 2\ub294 2\ubbf8\ud130 \uc774\uc0c1 18\ubbf8\ud130 \uc774\ud558 \ub5a8\uc5b4\uc9c4 \uacf3\uc5d0 \uac00\ub824\ub294 \uc2b9\uac1d\uc744 \ud0dc\uc6b8 \uc758\ud5a5\uc774 \uc788\uace0, \uc6b4\uc804\uc790 3\uc740 25\ubbf8\ud130 \uc774\uc0c1 35\ubbf8\ud130 \uc774\ud558 \ub5a8\uc5b4\uc9c4 \uacf3\uc5d0 \uac00\ub824\ub294 \uc2b9\uac1d\uc744 \ud0dc\uc6b8 \uc758\ud5a5\uc774 \uc788\ub2e4.<\/p>\r\n\r\n<p>\uc774 \uacbd\uc6b0, \uc2b9\uac1d1-\uc6b4\uc804\uc7902, \uc2b9\uac1d3-\uc6b4\uc804\uc7903\uc744 \ub9e4\uce6d\uc2dc\ucf1c\uc8fc\uba74 \ucd1d \ub450 \uc30d\uc744 \ub9e4\uce6d\uc2dc\ud0ac \uc218 \uc788\uace0 \uc774\ubcf4\ub2e4 \ub9ce\uc740 \uc218\uc758 \uc2b9\uac1d-\uc6b4\uc804\uc790\ub97c \ub9e4\uce6d \uc2dc\ud0ac \uc218 \uc788\ub294 \ubc29\ubc95\uc740 \uc5c6\ub2e4.<\/p>\r\n\r\n<p>\uc785\ub825\uc73c\ub85c N, M, \uadf8\ub9ac\uace0 x, y, z \uac12\ub4e4\uc744 \uc785\ub825 \ubc1b\uc544 \ucd5c\ub300\ud55c \ub9ce\uc740 \uc2b9\uac1d-\uc6b4\uc804\uc790 \uc30d\uc744 \ub9e4\uce6d\uc2dc\ud0a4\uba74 \uba87 \uc30d\uc744 \ub9e4\uce6d \uc2dc\ud0ac \uc218 \uc788\ub294\uc9c0 \uacc4\uc0b0\ud558\ub294 \ud504\ub85c\uadf8\ub7a8\uc744 \uc791\uc131\ud558\uc2dc\uc624.<\/p>\r\n","input":"<p>\uccab \uc904\uc5d0 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uc218 T\uac00 \uc8fc\uc5b4\uc9c4\ub2e4 (1 &le;&nbsp;T &le; 10).<\/p>\r\n\r\n<p>\uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uccab \uc904\uc5d0\ub294 N, M \uc774 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n\r\n<p>\uadf8 \ub2e4\uc74c \uc904\uc5d0 x<sub>i<\/sub> \uac00 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4 (1 &le; x<sub>i<\/sub>&nbsp;&le;&nbsp;1,000,000,000).<\/p>\r\n\r\n<p>\ub2e4\uc74c M\uc904\uc5d0 \uac78\uccd0 \uac01 \uc904\uc5d0 y<sub>j<\/sub> \uc640 z<sub>j<\/sub> \uac00 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4 (1 &le; y<sub>j<\/sub> &le; z<sub>j<\/sub> &le; 1,000,000,000).<\/p>\r\n","output":"<p>\uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc5d0 \ub300\ud574, \ucd5c\ub300\ud55c \ub9ce\uc740 \uc2b9\uac1d-\uc6b4\uc804\uc790\ub97c \ub9e4\uce6d \uc2dc\ucf30\uc744 \ub54c \uba87 \uc30d\uc744 \ub9e4\uce6d\uc2dc\ud0ac \uc218 \uc788\ub294\uc9c0 \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n","hint":"","original":"1","html_title":"0","problem_lang_tcode":"Korean","subtask1":"<ul>\r\n\t<li>1 &le; N, M &le; 100<\/li>\r\n<\/ul>\r\n","subtask2":"<ul>\r\n\t<li>1 &le; N, M &le; 100,000<\/li>\r\n<\/ul>\r\n"},{"problem_id":"17280","problem_lang":"1","title":"Carpool Matching","description":"<p>You need to help your friend, Albert, who&rsquo;s developing a new carpool app. In particular, you need to design a matching algorithm for drivers and riders. For the initial version of the app, the service will be provided in selected regions only, which are located along a long horizontal road.<\/p>\r\n\r\n<ul>\r\n\t<li>Every driver and rider leave from &ldquo;the city&rdquo; that&rsquo;s located at the far left on the road. All other cities are located to the right of the city.<\/li>\r\n\t<li>There are N riders, and the i-th rider wants to get to a place that&rsquo;s x<sub>i<\/sub> meters (0 &lt; x<sub>i<\/sub>) away from &ldquo;the city&rdquo; (that is, x<sub>i<\/sub> meters to the right of &ldquo;the city&rdquo;).<\/li>\r\n\t<li>There are M drivers, and the j-th driver is willing to give a ride to at most one rider whose destination is between y<sub>j<\/sub> and z<sub>j<\/sub> meters away from &ldquo;the city&rdquo;, inclusive.<\/li>\r\n<\/ul>\r\n\r\n<p>You need to meet these constraints while matching the most number of riders and drivers.<\/p>\r\n\r\n<p>For instance, suppose that there are 3 riders and 3 drivers with x, y, z values as follows:<\/p>\r\n\r\n<ul>\r\n\t<li>x = [10, 20, 30]<\/li>\r\n\t<li>y = [8, 2, 25]<\/li>\r\n\t<li>z = [8, 18, 35]<\/li>\r\n<\/ul>\r\n\r\n<p>In this case, the riders want to get to other cities that are 10m, 20m, and 30m away from &ldquo;the city&rdquo; while driver 1 is willing to give a ride to someone heading to a place exactly 8m away, driver 2 is willing to give a ride if someone&rsquo;s going to a place that is 2m or further away but no more than 18m away, and driver 3 with a 25m-35m range.&nbsp;<\/p>\r\n\r\n<p>In this case, we can match (rider 1, driver2) and (rider 3, driver 3) -- there is no way to match more than two pairs.&nbsp;<\/p>\r\n\r\n<p>Given N, M, and x, y, z values, compute the maximum number of rider-driver pairs you can match while meeting the said constraints.<\/p>\r\n","input":"<p>The first line will contain the number of test cases, T (1 &le; T &le; 10).<\/p>\r\n\r\n<p>For each test case, the first line will contain two integers N and M.<\/p>\r\n\r\n<p>The next line will contain N integers separated by whitespace, representing x<sub>i<\/sub>&rsquo;s (1 &le; x<sub>i<\/sub> &le; 1,000,000,000).<\/p>\r\n\r\n<p>The next M lines will contain two integers each, representing y<sub>j<\/sub> and z<sub>j<\/sub> (1 &le; y<sub>j<\/sub> &le; z<sub>j<\/sub> &le; 1,000,000,000).<\/p>\r\n","output":"<p>For each test case, output in a single line the maximum number of rider-driver pairs you can match.<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"English","subtask1":"<ul>\r\n\t<li>1 &le; N, M &le; 100<\/li>\r\n<\/ul>\r\n","subtask2":"<ul>\r\n\t<li>1 &le; N, M &le; 100,000<\/li>\r\n<\/ul>\r\n"}]

채점 및 기타 정보

  • 예제는 채점하지 않는다.