#4571. E. Blackslex and Girls

E. Blackslex and Girls

当前没有测试数据。

E. Blackslex and Girls

时间限制:2秒
内存限制:256兆字节
输入:标准输入
输出:标准输出

在尝试用固定长度比特串的德布鲁因序列搭讪失败后,Blackslex 将注意力转向了政治。

凭借出众的个人魅力,他现在负责为国家的 nn 个选区划分边界。在 Blackslex 的国家中,有 xx 名支持 A 党的选民和 yy 名支持 B 党的选民。借助出色的绘图技巧,他可以将任意党派的选民分配到任意选区内。

比特串相关的经历让他突发奇想:能否通过分配选民,使得每个选区的获胜党派遵循特定的比特串模式?为避免引起怀疑,每个选区还必须至少分配 pip_i 名选民。请你判断这是否可行!

题目描述

给定一个长度为 nn 的二进制字符串 ss、一个长度为 nn 的数组 pp,以及两个整数 xxyy。请判断是否存在两个长度为 nn 的非负整数数组 aabb,满足以下所有条件:

  1. a1+a2++an=xa_1 + a_2 + \dots + a_n = x(所有 A 党选民均被分配);
  2. b1+b2++bn=yb_1 + b_2 + \dots + b_n = y(所有 B 党选民均被分配);
  3. 对于每个 1in1 \leq i \leq nai+bipia_i + b_i \geq p_i(第 ii 个选区至少有 pip_i 名选民);
  4. 对于每个 1in1 \leq i \leq n
    • si=0s_i = 0,则 ai>bia_i > b_i(A 党在第 ii 个选区获胜);
    • si=1s_i = 1,则 bi>aib_i > a_i(B 党在第 ii 个选区获胜)。

输入格式

第一行包含一个整数 tt1t1041 \leq t \leq 10^4)—— 测试用例的数量。 每组测试用例的输入如下:

  • 第一行:三个整数 nnxxyy1n21051 \leq n \leq 2 \cdot 10^51x,y1091 \leq x, y \leq 10^9);
  • 第二行:一个长度为 nn 的二进制字符串 ss
  • 第三行:nn 个整数 p1,p2,,pnp_1, p_2, \dots, p_n1pi1091 \leq p_i \leq 10^9)。

所有测试用例的 nn 之和不超过 21052 \cdot 10^5

输出格式

对于每组测试用例,输出 YESNO(不区分大小写),表示是否存在满足条件的数组 aabb

样例输入

6
3 5 5
010
2 4 3
4 2 3
0001
1 1 1 1
2 4 2
00
3 3
4 23 20
1111
2 2 2 2
1 25 26
0
51
2 4 2
00
3 4

样例输出

YES
NO
YES
NO
NO
NO

样例解释

  • 第一组测试用例:一种可行的分配方案为 a=[2,0,3]a = [2, 0, 3]b=[0,4,1]b = [0, 4, 1]。此时:
    • aa 数组总和为 2+0+3=5=x2+0+3=5=xbb 数组总和为 0+4+1=5=y0+4+1=5=y
    • 每个选区的选民总数:2+0=2p1=22+0=2 \geq p_1=20+4=4p2=40+4=4 \geq p_2=43+1=4p3=33+1=4 \geq p_3=3
    • 选区获胜情况:s1=0s_1=02>02>0s2=1s_2=14>04>0s3=0s_3=03>13>1,均满足要求。
  • 第三组测试用例:一种可行的分配方案为 a=[2,2]a = [2, 2]b=[1,1]b = [1, 1]。此时:
    • aa 数组总和为 2+2=4=x2+2=4=xbb 数组总和为 1+1=2=y1+1=2=y
    • 每个选区的选民总数:2+1=3p1=32+1=3 \geq p_1=32+1=3p2=32+1=3 \geq p_2=3
    • 选区获胜情况:s1=0s_1=02>12>1s2=0s_2=02>12>1,均满足要求。
  • 其他测试用例均无法找到满足所有条件的分配方案。