比赛场次 | 622 |
---|---|
比赛名称 | 2024暑假C班集训C |
比赛状态 | 已结束比赛成绩 |
开始时间 | 2024-07-12 08:00:00 |
结束时间 | 2024-07-12 12:00:00 |
开放分组 | 全部用户 |
注释介绍 |
题目名称 | 喵星人集会 |
---|---|
输入输出 | party.in/out |
时间限制 | 1000 ms (1 s) |
内存限制 | 512 MiB |
测试点数 | 10 简单对比 |
用户 | 结果 | 时间 | 内存 | 得分 |
---|---|---|---|---|
dream | AWWWWWWWWW | 0.038 s | 3.35 MiB | 10 |
123 | WWWATTTTTT | 11.450 s | 3.43 MiB | 10 |
liuyiche | C | 0.000 s | 0.00 MiB | 0 |
LikableP | WWWWWWWWWW | 0.028 s | 3.42 MiB | 0 |
袁书杰 | WWWWWWWWWW | 0.030 s | 3.41 MiB | 0 |
彭欣越 | WWWWTTTTTT | 12.718 s | 3.25 MiB | 0 |
djyqjy | TTTTTTTTTT | 19.979 s | 3.25 MiB | 0 |
现在有一颗$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$。