2024年9月GESP 7级编程题

小杨寻宝

题目描述

小杨有一棵包含 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 n1 行,每行包含两个正整数 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 2134 的顺序即可成功取得所有宝物。

数据范围

子任务编号数据点占比 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 1t10,1n105,0ai1 ,且保证树上一定有至少一个节点放置有宝物。

矩阵移动

题目描述

小杨有一个有一个 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 1t10,1n,m500,1x300 ,同时保证所有测试用例 n × m n \times m n×m 的总和不超过 2.5 × 1 0 5 2.5 \times 10^5 2.5×105

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值