2024年6月GESP 7级编程题

黑白翻转

题目描述

小杨有一棵包含 n n n 个节点的树,这棵树上的任意一个节点要么是白色,要么是黑色。小杨认为一棵树是美丽树当且仅当在删除所有白色节点之后,剩余节点仍然组成一棵树。

小杨每次操作可以选择一个白色节点将它的颜色变为黑色,他想知道自己最少要执行多少次操作可以使得这棵树变为美丽树。

输入格式

第一行包含一个正整数 n n n,代表树的节点数。

第二行包含 n n n 个非负整数 a 1 , a 2 , … , a n a_1,a_2,\ldots,a_n a1,a2,,an,其中如果 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 的边。

输出格式

输出一个整数,代表最少执行的操作次数。

样例 #1

样例输入 #1

5
0 1 0 1 0
1 2
1 3
3 4
3 5

样例输出 #1

2

提示

样例解释

将节点 1 1 1 3 3 3 变为黑色即可使这棵树变为美丽树,此时删除白色节点 5 5 5,剩余黑色节点仍然组成一棵树。

数据范围

子任务编号数据点占比 n n n a i a_i ai特殊条件
1 1 1 30 % 30\% 30% ≤ 1 0 5 \leq 10^5 105 0 ≤ a i ≤ 1 0\leq a_i\leq 1 0ai1树的形态为一条链
2 2 2 30 % 30\% 30% ≤ 1 0 5 \leq 10^5 105 0 ≤ a i ≤ 1 0\leq a_i\leq 1 0ai1只有两个节点颜色为黑色
3 3 3 40 % 40\% 40% ≤ 1 0 5 \leq 10^5 105 0 ≤ a i ≤ 1 0\leq a_i\leq 1 0ai1

对于全部数据,保证有 1 ≤ n ≤ 1 0 5 1\leq n\leq 10^5 1n105 0 ≤ a i ≤ 1 0\leq a_i\leq 1 0ai1

区间乘积

题目描述

小杨有一个包含 n n n 个正整数的序列 A = [ a 1 , a 2 , … , a n ] A=[a_1,a_2,\ldots,a_n] A=[a1,a2,,an]

小杨想知道有多少对 ⟨ l , r ⟩ ( 1 ≤ l ≤ r ≤ n ) \langle l,r\rangle(1\leq l\leq r\leq n) l,r(1lrn) 满足 a l × a l + 1 × … × a r a_l\times a_{l+1}\times\ldots\times a_r al×al+1××ar 为完全平方数。

一个正整数 x x x 为完全平方数当且仅当存在一个正整数 y y y 使得 x = y × y x=y\times y x=y×y

输入格式

第一行包含一个正整数 n n n,代表正整数个数。

第二行包含 n n n 个正整数 a i a_i ai,代表序列 A A A

输出格式

输出一个整数,代表满足要求的 ⟨ l , r ⟩ \langle l,r\rangle l,r 数量。

样例 #1

样例输入 #1

5
3 2 4 3 2

样例输出 #1

2

提示

样例解释

满足条件的 ⟨ l , r ⟩ \langle l,r\rangle l,r ⟨ 1 , 5 ⟩ \langle 1,5\rangle 1,5 ⟨ 3 , 3 ⟩ \langle 3,3\rangle 3,3

数据范围

子任务编号数据点占比 n n n a i a_i ai
1 1 1 20 % 20\% 20% ≤ 1 0 5 \leq 10^5 105 1 ≤ a i ≤ 2 1\leq a_i\leq 2 1ai2
2 2 2 40 % 40\% 40% ≤ 100 \leq 100 100 1 ≤ a i ≤ 30 1\leq a_i\leq 30 1ai30
3 3 3 40 % 40\% 40% ≤ 1 0 5 \leq 10^5 105 1 ≤ a i ≤ 30 1\leq a_i\leq 30 1ai30
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值