小杨寻宝
题目描述
小杨有一棵包含 n n n 个节点的树,树上的一些节点放置有宝物。
小杨可以任意选择一个节点作为起点并在树上移动,但是小杨只能经过每条边至多一次,当小杨经过一条边后,这条边就会消失。小杨每经过一个放置有宝物的节点就会取得该宝物。
小杨想请你帮他判断自己能否成功取得所有宝物。
输入格式
第一行包含一个正整数 t t t ,代表测试用例组数。
接下来是 t t t 组测试用例。对于每组测试用例,一共 n + 1 n+1 n+1 行。
第一行包含一个正整数 n n n ,代表树的节点数。
第二行包含 n n n 个非负整数 a 1 , a 2 , … , a n a_1,a_2,\ldots,a_n a1,a2,…,an ,其中如果 a i = 1 a_i=1 ai=1 ,则节点 i i i 放置有宝物,若 a i = 0 a_i = 0 ai=0 ,则节点 i i i 没有宝物。
之后 n − 1 n-1 n−1 行,每行包含两个正整数 x i , y i x_i,y_i xi,yi ,代表存在一条连接节点 x i x_i xi 和 y i y_i yi 的边。
输出格式
对于每组测试数据,如果小杨能成功取得所有宝物,输出 Yes
,否则输出 No
。
样例 #1
样例输入 #1
2
5
0 1 0 1 0
1 2
1 3
3 4
3 5
5
1 1 1 1 1
1 2
1 3
3 4
3 5
样例输出 #1
Yes
No
提示
样例解释
对于第一组测试用例,小杨从节点 2 2 2 出发,按照 2 − 1 − 3 − 4 2-1-3-4 2−1−3−4 的顺序即可成功取得所有宝物。
数据范围
子任务编号 | 数据点占比 | n n n |
---|---|---|
1 1 1 | 20 % 20\% 20% | ≤ 5 \leq 5 ≤5 |
2 2 2 | 20 % 20\% 20% | ≤ 1000 \leq 1000 ≤1000 |
3 3 3 | 60 % 60\% 60% | ≤ 1 0 5 \leq 10^5 ≤105 |
对于全部数据,保证有 1 ≤ t ≤ 10 , 1 ≤ n ≤ 1 0 5 , 0 ≤ a i ≤ 1 1\leq t\leq 10,1\leq n \leq 10^5,0\leq a_i\leq 1 1≤t≤10,1≤n≤105,0≤ai≤1 ,且保证树上一定有至少一个节点放置有宝物。
矩阵移动
题目描述
小杨有一个有一个
n
×
m
n \times m
n×m 的矩阵,仅包含 0
1
?
三种字符。矩阵的行从上到下编号依次为
1
,
2
,
…
,
n
1,2,\ldots,n
1,2,…,n ,列从左到右编号依次为
1
,
2
,
…
,
m
1,2,\ldots,m
1,2,…,m 编号。小杨开始在矩阵的左上角
(
1
,
1
)
(1,1)
(1,1) ,小杨只能向下或者向右移动,最终到达右下角
(
n
,
m
)
(n,m)
(n,m) 时停止,在移动的过程中每经过一个字符 1
得分会增加一分(包括起点和终点),经过其它字符则分数不变。小杨的初始分数为
0
0
0 分。
小杨可以将矩阵中不超过
x
x
x 个字符 ?
变为字符 1
。小杨在修改矩阵后,会以最优的策略从左上角移动到右下角。他想知道自己最多能获得多少分。
输入格式
第一行包含一个正整数 t t t ,代表测试用例组数。
接下来是 t t t 组测试用例。对于每组测试用例,一共 n + 1 n+1 n+1 行。
第一行包含三个正整数 n , m , x n,m,x n,m,x ,含义如题面所示。
之后
n
n
n 行,每行包含一个长度为
m
m
m 且仅包含 0
1
?
三种字符的字符串。
输出格式
对于每组测试用例,输出一行一个整数,代表最优策略下小杨的得分最多是多少。
样例 #1
样例输入 #1
2
3 3 1
000
111
01?
3 3 1
000
?0?
01?
样例输出 #1
4
2
提示
样例解释
对于第二组测试用例,将
(
1
,
1
)
(1,1)
(1,1) 或者
(
3
,
3
)
(3,3)
(3,3) 变成 1
均是最优策略。
数据范围
子任务编号 | 数据点占比 | t t t | n , m n,m n,m | x x x |
---|---|---|---|---|
1 1 1 | 30 % 30\% 30% | ≤ 15 \leq 15 ≤15 | ≤ 10 \leq 10 ≤10 | = 1 =1 =1 |
2 2 2 | 30 % 30\% 30% | ≤ 10 \leq 10 ≤10 | ≤ 500 \leq 500 ≤500 | ≤ 30 \leq30 ≤30 |
3 3 3 | 40 % 40\% 40% | ≤ 10 \leq 10 ≤10 | ≤ 500 \leq 500 ≤500 | ≤ 300 \leq300 ≤300 |
对于全部数据,保证有 1 ≤ t ≤ 10 , 1 ≤ n , m ≤ 500 , 1 ≤ x ≤ 300 1 \leq t \leq 10,1 \leq n,m \leq 500,1 \leq x \leq 300 1≤t≤10,1≤n,m≤500,1≤x≤300 ,同时保证所有测试用例 n × m n \times m n×m 的总和不超过 2.5 × 1 0 5 2.5 \times 10^5 2.5×105 。