CF1282C.Petya and Exam

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

Petya has come to the math exam and wants to solve as many problems as possible. He prepared and carefully studied the rules by which the exam passes.

The exam consists of nn problems that can be solved in TT minutes. Thus, the exam begins at time 00 and ends at time TT . Petya can leave the exam at any integer time from 00 to TT , inclusive.

All problems are divided into two types:

  • easy problems — Petya takes exactly aa minutes to solve any easy problem;
  • hard problems — Petya takes exactly bb minutes ( b>ab > a ) to solve any hard problem.

Thus, if Petya starts solving an easy problem at time xx , then it will be solved at time x+ax+a . Similarly, if at a time xx Petya starts to solve a hard problem, then it will be solved at time x+bx+b .

For every problem, Petya knows if it is easy or hard. Also, for each problem is determined time tit_i ( 0tiT0 \le t_i \le T ) at which it will become mandatory (required). If Petya leaves the exam at time ss and there is such a problem ii that tist_i \le s and he didn't solve it, then he will receive 00 points for the whole exam. Otherwise (i.e if he has solved all such problems for which tist_i \le s ) he will receive a number of points equal to the number of solved problems. Note that leaving at time ss Petya can have both "mandatory" and "non-mandatory" problems solved.

For example, if n=2n=2 , T=5T=5 , a=2a=2 , b=3b=3 , the first problem is hard and t1=3t_1=3 and the second problem is easy and t2=2t_2=2 . Then:

  • if he leaves at time s=0s=0 , then he will receive 00 points since he will not have time to solve any problems;
  • if he leaves at time s=1s=1 , he will receive 00 points since he will not have time to solve any problems;
  • if he leaves at time s=2s=2 , then he can get a 11 point by solving the problem with the number 22 (it must be solved in the range from 00 to 22 );
  • if he leaves at time s=3s=3 , then he will receive 00 points since at this moment both problems will be mandatory, but he will not be able to solve both of them;
  • if he leaves at time s=4s=4 , then he will receive 00 points since at this moment both problems will be mandatory, but he will not be able to solve both of them;
  • if he leaves at time s=5s=5 , then he can get 22 points by solving all problems.

Thus, the answer to this test is 22 .

Help Petya to determine the maximal number of points that he can receive, before leaving the exam.

输入格式

The first line contains the integer mm ( 1m1041 \le m \le 10^4 ) — the number of test cases in the test.

The next lines contain a description of mm test cases.

The first line of each test case contains four integers n,T,a,bn, T, a, b ( 2n21052 \le n \le 2\cdot10^5 , 1T1091 \le T \le 10^9 , 1a<b1091 \le a < b \le 10^9 ) — the number of problems, minutes given for the exam and the time to solve an easy and hard problem, respectively.

The second line of each test case contains nn numbers 00 or 11 , separated by single space: the ii -th number means the type of the ii -th problem. A value of 00 means that the problem is easy, and a value of 11 that the problem is hard.

The third line of each test case contains nn integers tit_i ( 0tiT0 \le t_i \le T ), where the ii -th number means the time at which the ii -th problem will become mandatory.

It is guaranteed that the sum of nn for all test cases does not exceed 21052\cdot10^5 .

输出格式

Print the answers to mm test cases. For each set, print a single integer — maximal number of points that he can receive, before leaving the exam.

输入输出样例

  • 输入#1

    10
    3 5 1 3
    0 0 1
    2 1 4
    2 5 2 3
    1 0
    3 2
    1 20 2 4
    0
    16
    6 20 2 5
    1 1 0 1 0 0
    0 8 2 9 11 6
    4 16 3 6
    1 0 1 1
    8 3 5 6
    6 20 3 6
    0 1 0 0 1 0
    20 11 3 20 16 17
    7 17 1 6
    1 1 0 1 0 0 0
    1 7 0 11 10 15 10
    6 17 2 6
    0 0 1 0 0 1
    7 6 3 7 10 12
    5 17 2 5
    1 1 1 1 0
    17 11 10 6 4
    1 1 1 2
    0
    1
    

    输出#1

    3
    2
    1
    0
    1
    4
    0
    1
    2
    1
    
首页