| 시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
|---|---|---|---|---|---|
| 1 초 | 1024 MB | 5 | 2 | 2 | 66.667% |
You aim to assemble a team of $N$ programmers. You've already scouted them and assessed that the skill level of the $i$-th individual (1ドル ≤ i ≤ N$) is represented by the nonnegative integer $s[i]$. You've realized that what truly matters is the order in which you hire them.
Each programmer is characterized by two additional integer values: workrate and motivation, both of which are 0ドル$ upon their arrival but can increase after hiring new team members. When a new programmer is hired, the following events occur in the given order:
The strength of the team is determined afterwards by the sum of the workrates of all the team members. Your objective is to calculate the maximum attainable team strength by optimizing the order of hiring.
For example, if you hire programmers with skill levels $(0, 2, 2, 3)$ in this order, the hiring process will affect their values as follows:
| Event | Workrates | Motivations |
|---|---|---|
| Hiring with skill 0ドル$ | 0ドル$ | 0ドル$ |
| Hiring with skill 2ドル$ | 0ドル$ 0ドル$ | 0ドル$ 0ドル$ |
| Workrates update | 0ドル$ 0ドル$ | 0ドル$ 0ドル$ |
| Motivations update | 0ドル$ 0ドル$ | 2ドル$ 0ドル$ |
| Hiring with skill 2ドル$ | 0ドル$ 0ドル$ 0ドル$ | 2ドル$ 0ドル$ 0ドル$ |
| Workrates update | 2ドル$ 0ドル$ 0ドル$ | 2ドル$ 0ドル$ 0ドル$ |
| Motivations update | 2ドル$ 0ドル$ 0ドル$ | 4ドル$ 2ドル$ 0ドル$ |
| Hiring with skill 3ドル$ | 2ドル$ 0ドル$ 0ドル$ 0ドル$ | 4ドル$ 2ドル$ 0ドル$ 0ドル$ |
| Workrates update | 6ドル$ 2ドル$ 0ドル$ 0ドル$ | 4ドル$ 2ドル$ 0ドル$ 0ドル$ |
| Motivations update | 6ドル$ 2ドル$ 0ドル$ 0ドル$ | 7ドル$ 5ドル$ 3ドル$ 0ドル$ |
The team strength will be calculated as 6ドル + 2 + 0 + 0 = 8$. However, if you hire programmers in better order $(2, 2, 3, 0),ドル you will achieve a team strength of 7ドル + 3 + 0 + 0 = 10$.
| New hire skill | Workrates | Motivations |
|---|---|---|
| 2ドル$ | 0ドル$ | 0ドル$ |
| 2ドル$ | 0ドル$ 0ドル$ | 2ドル$ 0ドル$ |
| 3ドル$ | 2ドル$ 0ドル$ 0ドル$ | 5ドル$ 3ドル$ 0ドル$ |
| 0ドル$ | 7ドル$ 3ドル$ 0ドル$ 0ドル$ | 5ドル$ 3ドル$ 0ドル$ 0ドル$ |
Furthermore, over the course of the upcoming $Q$ days, you will receive notifications about changes in the skill level assessments of certain programmers. After day $i,ドル the skill level of programmer $x[i]$ will be updated to $y[i]$ (which may match the previous value). This updated skill value will be used in the following days, until it potentially gets updated again.
After each day, starting from today, your goal is to determine the maximum achievable team strength by hiring all $N$ programmers, taking into account the assessed skill levels at that particular moment.
The first line contains two integers: $N$ and $Q$.
The second line contains integers: $s[1],ドル $s[2],ドル $\dots,ドル $s[N]$.
Subsequently, there are $Q$ lines, the $i$-th of which contains two integers: $x[i]$ and $y[i]$.
Print $Q + 1$ lines, each containing a single integer. These integers represent the maximum potential team strength after each day, in chronological order.
| 번호 | 배점 | 제한 |
|---|---|---|
| 1 | 11 | $N ≤ 7$; $Q ≤ 100$ |
| 2 | 19 | $N,Q ≤ 500$ |
| 3 | 15 | $Q ≤ 10$ |
| 4 | 6 | The skill levels never exceed 1ドル$. |
| 5 | 9 | The skill levels never exceed 500ドル$. |
| 6 | 12 | $x[i] = 1$ for each 1ドル ≤ i ≤ Q$. |
| 7 | 10 | Each update will change the skill level by at most 1ドル$. |
| 8 | 18 | No additional constraints. |
4 2 2 0 2 3 2 4 4 0
10 14 12
The solution for the initial state is illustrated above. After the first day, the skill levels will be updated to $(2, 4, 2, 3)$ and the maximum attainable team strength becomes 14ドル,ドル and after the second day, they will be further adjusted to $(2, 4, 2, 0)$.