# P1230 智力大冲浪
## 题目描述
小伟报名参加中央电视台的智力大冲浪节目。本次挑战赛吸引了众多参赛者,主持人为了表彰大家的勇气,先奖励每个参赛者 $m$ 元。先不要太高兴,因为这些钱还不一定都是你的。接下来主持人宣布了比赛规则:
首先,比赛时间分为 $n$ 个时段,它又给出了很多小游戏,每个小游戏都必须在规定期限 $t_i$ 前完成。如果一个游戏没能在规定期限前完成,则要从奖励费 $m$ 元中扣去一部分钱 $w_i$,$w_i$ 为自然数,不同的游戏扣去的钱是不一样的。当然,每个游戏本身都很简单,保证每个参赛者都能在一个时段内完成,而且都必须从整时段开始。主持人只是想考考每个参赛者如何安排组织自己做游戏的顺序。作为参赛者,小伟很想赢得冠军,当然更想赢取最多的钱!注意:比赛绝对不会让参赛者赔钱!
## 输入格式
第一行为 $m$,表示一开始奖励给每位参赛者的钱;
第二行为 $n$,表示有 $n$ 个小游戏;
第三行有 $n$ 个数,分别表示游戏 $1$ 到 $n$ 的规定完成期限;
第四行有 $n$ 个数,分别表示游戏 $1$ 到 $n$ 不能在规定期限前完成的扣款数。
## 输出格式
输出仅一行,表示小伟能赢取最多的钱。
## 输入输出样例 #1
### 输入 #1
```
10000
7
4 2 4 3 1 4 6
70 60 50 40 30 20 10
```
### 输出 #1
```
9950
```
## 说明/提示
对于 $100\%$ 的数据,$1 \le n \le 500$,$1 \le m \le 5 \times 10^5$,$1 \le t_i \le n$,$1 \le w_i \le 1000$。
正解
这道题意思是让我们在规定的时间内完成哪些任务可以让赚的钱最大化,那么我们不妨按照扣钱来从大到小排序,然后按照比它小或者和它一样的时间内有没有完成的任务,没有就把它方到那,如果有,那就说明有比它扣钱还多的任务需要完成
#include<iostream>
#include<algorithm>
#include<cstring>using namespace std;
const int N = 510;
typedef pair<int, int>PII;
int n, m;
struct node
{
int h, w;
bool flag;
bool operator<(node& t)const {
return w > t.w;
}
}per[N];bool st[N];
int main()
{
cin >> m >> n;for (int i = 1; i <= n; i++) cin >> per[i].h;
for (int i = 1; i <= n; i++) cin >> per[i].w;
sort(per + 1, per + 1 + n);for (int i = 1; i <= n; i++) {
for (int j = per[i].h; j >= 1; j--) {
if (!st[j]) {
per[i].flag = true;
st[j] = true;
break;
}
}
}for (int i = 1; i <= n; i++) {
if (!per[i].flag) m -= per[i].w;
}cout << m << endl;
return 0;
}