比赛场次 654
比赛名称 2025.1.4
比赛状态 已结束比赛成绩
开始时间 2025-01-04 08:00:00
结束时间 2025-01-04 18:00:00
开放分组 全部用户
注释介绍
题目名称 喵星人集会
输入输出 party.in/out
时间限制 1000 ms (1 s)
内存限制 512 MiB
测试点数 10 简单对比
用户 结果 时间 内存 得分
Gravatar李奇文 AWWWWAWWWW 0.033 s 3.39 MiB 20
GravatarDavinci WWWWWAWWWW 0.030 s 3.33 MiB 10
Gravatarwdsjl WWWWWWWWWW 0.031 s 3.60 MiB 0
Gravatar健康铀 WWWWWWWWWW 0.032 s 3.41 MiB 0

喵星人集会

★★★   输入文件:party.in   输出文件:party.out   简单对比
时间限制:1 s   内存限制:512 MiB

【题目描述】

现在有一颗$n$个点的树,其中某些点有一个喵星人.

现在他们要到某个地方进行集会,但是肯定不能都聚到一个点,因为放不下- -.

事实上,一个点还是只能容纳一只喵星人。

但是他们要尽可能靠近,也就是说:任意两只喵星人之间的路径上不能存在一个没有喵星人的点.

但是现在它们显然还没有这样的靠近.

每一个喵星人都可以从原来所处的位置移动到另一个位置,消耗的体力为两个位置之间的路径的边数.

现在你要让某些喵星人移动到另外的位置,使得他们尽可能靠近.在此前提下使得所有喵星人消耗的体力之和尽可能小.

注意的是,你不用考虑喵星人之间的相互影响.

【输入格式】

第一行一个整数$n$,表示树上的点数.

第二行一个长度为$n$的01串,若第$i$位为1则表示标号为$i$点开始时有一只喵星人.

接下来$n-1$行,每行两个整数$u, v$,表示标号为$u$的点与标号为$v$的点之间有一条无向边.

【输出格式】

如存在一种合法的移动方法,输出一行一个整数,表示所有喵星人花费的体力值之和最小值.

否则输出除了QwQ之外的任意一个卖萌表情.

【样例输入】

6
001101
1 2
2 3
3 4
2 5
1 6

【样例输出】

2

【数据规模与约定】

对于$20\%$的数据,保证喵星人的数目$≤ 3$.

对于$50\%$的数据,$n ≤ 20$,保证喵星人的数目$≤ 8$.

对于$100\%$的数据,$1 ≤ n ≤ 50$,$1 ≤喵星人的数目≤ n$。

大样例