CF883J.Renovation
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
The mayor of the Berland city S sees the beauty differently than other city-dwellers. In particular, he does not understand at all, how antique houses can be nice-looking. So the mayor wants to demolish all ancient buildings in the city.
The city S is going to host the football championship very soon. In order to make the city beautiful, every month the Berland government provides mayor a money tranche. The money has to be spent on ancient buildings renovation.
There are n months before the championship and the i -th month tranche equals to ai burles. The city S has m antique buildings and the renovation cost of the j -th building is bj burles.
The mayor has his own plans for spending the money. As he doesn't like antique buildings he wants to demolish as much of them as possible. For the j -th building he calculated its demolishing cost pj .
The mayor decided to act according to the following plan.
Each month he chooses several (possibly zero) of m buildings to demolish in such a way that renovation cost of each of them separately is not greater than the money tranche ai of this month ( bj<=ai ) — it will allow to deceive city-dwellers that exactly this building will be renovated.
Then the mayor has to demolish all selected buildings during the current month as otherwise the dwellers will realize the deception and the plan will fail. Definitely the total demolishing cost can not exceed amount of money the mayor currently has. The mayor is not obliged to spend all the money on demolishing. If some money is left, the mayor puts it to the bank account and can use it in any subsequent month. Moreover, at any month he may choose not to demolish any buildings at all (in this case all the tranche will remain untouched and will be saved in the bank).
Your task is to calculate the maximal number of buildings the mayor can demolish.
输入格式
The first line of the input contains two integers n and m (1<=n,m<=100000) — the number of months before the championship and the number of ancient buildings in the city S.
The second line contains n integers a1,a2,...,an ( 1<=ai<=109 ), where ai is the tranche of the i -th month.
The third line contains m integers b1,b2,...,bm ( 1<=bj<=109 ), where bj is renovation cost of the j -th building.
The fourth line contains m integers p1,p2,...,pm ( 1<=pj<=109 ), where pj is the demolishing cost of the j -th building.
输出格式
Output single integer — the maximal number of buildings the mayor can demolish.
输入输出样例
输入#1
2 3 2 4 6 2 3 1 3 2
输出#1
2
输入#2
3 5 5 3 1 5 2 9 1 10 4 2 1 3 10
输出#2
3
输入#3
5 6 6 3 2 4 3 3 6 4 5 4 2 1 4 3 2 5 3
输出#3
6
说明/提示
In the third example the mayor acts as follows.
In the first month he obtains 6 burles tranche and demolishes buildings #2 (renovation cost 6 , demolishing cost 4 ) and #4 (renovation cost 5 , demolishing cost 2 ). He spends all the money on it.
After getting the second month tranche of 3 burles, the mayor selects only building #1 (renovation cost 3 , demolishing cost 1 ) for demolishing. As a result, he saves 2 burles for the next months.
In the third month he gets 2 burle tranche, but decides not to demolish any buildings at all. As a result, he has 2+2=4 burles in the bank.
This reserve will be spent on the fourth month together with the 4 -th tranche for demolishing of houses #3 and #5 (renovation cost is 4 for each, demolishing costs are 3 and 5 correspondingly). After this month his budget is empty.
Finally, after getting the last tranche of 3 burles, the mayor demolishes building #6 (renovation cost 2 , demolishing cost 3 ).
As it can be seen, he demolished all 6 buildings.