黑白翻转
题目描述
小杨有一棵包含 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 n−1 行,每行包含两个正整数 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 0≤ai≤1 | 树的形态为一条链 |
2 2 2 | 30 % 30\% 30% | ≤ 1 0 5 \leq 10^5 ≤105 | 0 ≤ a i ≤ 1 0\leq a_i\leq 1 0≤ai≤1 | 只有两个节点颜色为黑色 |
3 3 3 | 40 % 40\% 40% | ≤ 1 0 5 \leq 10^5 ≤105 | 0 ≤ a i ≤ 1 0\leq a_i\leq 1 0≤ai≤1 |
对于全部数据,保证有 1 ≤ n ≤ 1 0 5 1\leq n\leq 10^5 1≤n≤105, 0 ≤ a i ≤ 1 0\leq a_i\leq 1 0≤ai≤1。
区间乘积
题目描述
小杨有一个包含 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⟩(1≤l≤r≤n) 满足 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 1≤ai≤2 |
2 2 2 | 40 % 40\% 40% | ≤ 100 \leq 100 ≤100 | 1 ≤ a i ≤ 30 1\leq a_i\leq 30 1≤ai≤30 |
3 3 3 | 40 % 40\% 40% | ≤ 1 0 5 \leq 10^5 ≤105 | 1 ≤ a i ≤ 30 1\leq a_i\leq 30 1≤ai≤30 |