CF1923B.Monsters Attack!
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
You are playing a computer game. The current level of this game can be modeled as a straight line. Your character is in point 0 of this line. There are n monsters trying to kill your character; the i -th monster has health equal to ai and is initially in the point xi .
Every second, the following happens:
- first, you fire up to k bullets at monsters. Each bullet targets exactly one monster and decreases its health by 1 . For each bullet, you choose its target arbitrary (for example, you can fire all bullets at one monster, fire all bullets at different monsters, or choose any other combination). Any monster can be targeted by a bullet, regardless of its position and any other factors;
- then, all alive monsters with health 0 or less die;
- then, all alive monsters move 1 point closer to you (monsters to the left of you increase their coordinates by 1 , monsters to the right of you decrease their coordinates by 1 ). If any monster reaches your character (moves to the point 0 ), you lose.
Can you survive and kill all n monsters without letting any of them reach your character?
输入格式
The first line of the input contains one integer t ( 1≤t≤3⋅104 ) — the number of test cases.
Each test case consists of three lines:
- the first line contains two integers n and k ( 1≤n≤3⋅105 ; 1≤k≤2⋅109 );
- the second line contains n integers a1,a2,…,an ( 1≤ai≤109 );
- the third line contains n integers x1,x2,…,xn ( −n≤x1<x2<x3<⋯<xn≤n ; xi=0 ).
Additional constraint on the input: the sum of n over all test cases does not exceed 3⋅105 .
输出格式
For each test case, print YES if you can kill all n monsters before they reach your character, or NO otherwise.
You can output each letter of the answer in any case (upper or lower). For example, the strings yEs, yes, Yes, and YES will all be recognized as positive responses.
输入输出样例
输入#1
5 3 2 1 2 3 -1 2 3 2 1 1 1 -1 1 4 10 3 4 2 5 -3 -2 1 3 5 3 2 1 3 2 5 -3 -2 3 4 5 2 1 1 2 1 2
输出#1
YES NO YES YES NO
说明/提示
In the first example, you can act as follows:
- during the 1 -st second, fire 1 bullet at the 1 -st monster and 1 bullet at the 3 -rd monster. Then the 1 -st monster dies, the 2 -nd and the 3 -rd monster move closer;
- during the 2 -nd second, fire 2 bullets at the 2 -nd monster. Then the 2 -nd monster dies, the 3 -rd monster moves closer;
- during the 3 -rd second, fire 2 bullets at the 3 -rd monster. Then the 3 -rd monster dies.
In the second example, you can fire only 1 bullet, so you can kill only one of the two monsters during the 1 -st second. Then, the remaining monster moves closer and kills your character.