| 시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
|---|---|---|---|---|---|
| 2 초 | 1024 MB | 180 | 62 | 53 | 34.868% |
두 개의 기둥 A, B가 나란히 놓여 있다. 각각의 기둥에는 $N$개의 손잡이가 달려 있고, 이 손잡이는 아래에서 위의 순서로 1부터 $N$까지 번호가 매겨져 있다. 각각의 기둥에는 0개 이상의 바나나가 매달려 있다. $A_i$는 기둥 A의 손잡이 $i$에 매달려 있는 바나나의 개수를, $B_j$는 기둥 B의 손잡이 $j$에 매달려 있는 바나나의 개수를 표현한다. 이 값들은 0 이상 10ドル^9$ 이하인 정수이다.
원숭이는 두 팔로 서로 다른 기둥의 손잡이를 잡을 수 있다. 같은 기둥의 손잡이 둘을 잡는 경우는 없음에 유의하라. 또한 원숭이가 아무 손잡이나 잡을 수 있는 것은 아니다. 원숭이가 잡을 수 있는 두 손잡이의 쌍은 $(x, y)$로 표현할 수 있는데, 이는 기둥 A의 손잡이 $x$와 기둥 B의 손잡이 $y$를 동시에 잡을 수 있다는 뜻이다. 이때 원숭이는 두 손잡이에 남아 있는 바나나를 모두 먹을 수 있다. 당연한 이야기이지만, 한 번 먹어버린 바나나는 사라진다. 이런 순서쌍은 총 $M$개 있다.
맨 처음 원숭이는 잡을 수 있는 두 손잡이의 쌍들 중 하나의 위치에서 출발한다. 현재 원숭이가 $(x, y)$의 위치에 있을 때, 다른 잡을 수 있는 두 손잡이의 쌍 $(x', y')$로 이동하려면 $x < x',ドル $y = y'$이거나 $x = x',ドル $y < y'$이어야 한다.
원숭이는 당연히도 바나나를 최대한 많이 먹고 싶어한다. 잡을 수 있는 손잡이들에 대한 정보와 이 손잡이들에 매달린 바나나의 수에 대한 정보가 주어졌을 때, 원숭이가 가장 많이 먹을 수 있는 바나나의 수를 구하는 프로그램을 작성하라.
여러분은 아래 함수를 구현해야 한다.
long long int max_bananas(vector<int> A, vector<int> B, vector< pair<int, int> > P)
A의 길이는 $N$이며, A[$i$]는 기둥 A의 $i+1$번째 손잡이에 매달려 있는 바나나의 개수이다$(0 \le i \le N-1)$.B의 길이는 $N$이며, B[$i$]는 기둥 B의 $i+1$번째 손잡이에 매달려 있는 바나나의 개수이다$(0 \le i \le N-1)$.P의 길이는 $M$이며, $(x, y)$가 P에 포함되어 있다면, 원숭이는 기둥 A의 손잡이 $x,ドル 기둥 B의 손잡이 $y$를 동시에 잡고 매달릴 수 있다. 이때, 두 손잡이에 남아 있는 바나나를 모두 먹을 수 있다. 같은 순서쌍이 여러 번 주어지지 않음이 보장된다.제출하는 소스 코드의 어느 부분에서도 입출력 함수를 실행해서는 안 된다.
P로 주어지는 순서쌍 $(x, y)$는 모두 서로 다르며, 1ドル \le x \le N,ドル 1ドル\le y \le N$을 만족한다.| 번호 | 배점 | 제한 |
|---|---|---|
| 1 | 11 | $M \le 16$ |
| 2 | 42 | $M \le 5,000円$ |
| 3 | 97 | 추가적인 제약 조건이 없다. |
그림과 같이 $N = 3,ドル $M = 3,ドル A $=$ [2, 3, 1], B $=$ [3, 2, 4], P $=$ [(1, 1), (2, 1), (1, 3)]인 경우를 생각해 보자.
그레이더는 다음 함수를 호출한다.
max_bananas([2, 3, 1], [3, 2, 4], [(1, 1), (2, 1), (1, 3)])
(1, 1) 위치에서 시작해, (1, 3) 위치로 이동하면 총 2ドル+3+4=9$개의 바나나를 먹을 수 있고, 이보다 바나나를 더 많이 먹을 수 있는 방법은 없다. 따라서 max_bananas 함수는 9를 반환해야 한다.
이 예제는 모든 부분문제의 조건을 만족한다.
Sample grader는 아래와 같은 형식으로 입력을 받는다.
A[0] A[1] $\cdots$ A[$N-1$]B[0] B[1] $\cdots$ B[$N-1$]P[$i-1$].first P[$i-1$].second Sample grader는 아래와 같은 형식으로 출력한다.
max_bananas가 반환한 값Sample grader는 실제 채점에서 사용하는 그레이더와 다를 수 있음에 유의하라.
Olympiad > 국제정보올림피아드 대표학생 선발고사 > 2021 > 2차 선발고사 3번
C++17, C++14, C++20, C++14 (Clang), C++17 (Clang), C++20 (Clang)