4 条题解

  • 2
    @ 2024-8-11 16:34:41

    数据人题解,仅提供思路导引。

    个人认为是一个个人差很大的题目。

    算法 1

    先画一棵 h=2h=2 的二叉树,如下图所示。

    然后列一张表格,表示 fu,kf_{u,k} 的值,根据题意可以得到:

    其中 vuv_u 是结点 uu 的权值。

    不难发现,f2,1f_{2,1}f3,1f_{3,1} 是相等的。因此只需要找到这三个点中 fu,1f_{u,1} 与其他两者不同的那个 uu 就行,剩下两者就是所需的 ww

    若三个相等,则 ww 仍然是 fu,1f_{u,1},而根结点 rr 只需要满足 fr,2=0f_{r,2}=0 即可。这个结论读者自证不难。期望得分 2020

    算法 2

    注意到对于根节点 rr,必有 fr,k=0f_{r,k}=0。因此找到符合这个条件的结点即可。

    对于根节点的权值,由于二叉树的每个结点的权值都为 ww,因此只需要找到 fu,kf_{u,k} 中的非零值即可。若没有非零值,则 w=0w=0

    期望得分 2020,结合算法 1 期望得分 4040

    算法 3.1

    考虑对 h=4h=4 列出 fu,kf_{u,k} 的表格。

    由于只有 hhfu,kf_{u,k},考虑对这张表格的每一行和每一列求异或和。

    然后你会发现,第 k(2kh)k(2 \leq k \leq h) 列的异或和与根节点的 fr,k1f_{r,k-1} 信息在数值上是能够对应上的。利用此规律就能找到根节点,期望得分 5050,结合前面算法期望得分 7070

    算法 3.2

    求出根节点之后,可以计算 fr,kf_{r,k} 的异或和,显然这个异或和是除了根节点外所有其他结点权值的异或和。

    给出一个结论(from Cfz):

    如果两个点的距离为奇数,那么将两个点中所有满足 dis\operatorname{dis} 为奇数的信息异或起来就能得到所有点的权值的异或和。如果两个点的距离为偶数,则异或起来会得到 00

    利用这个结论就能直接求出所有结点权值的异或和。

    如何发现这个结论?可以观察一下表格去凑出所有结点权值的异或和,由于直接取一列的异或和会把根节点的权值消掉,所以考虑只使用两行信息,然后就能凑出来了。

    于是根节点的权值就求出来了,期望得分 100100

    造数据思路

    确定每个结点的权值之后使用树形 dp 得到输入数据。

    第一个子任务造法比较鲁莽:所有点随机权值、所有点权值为零、部分点权值为零其余随机、所有点权值为同一个值等等。造了一个 T=1000T=1000 的测试点。

    第二个子任务由于特殊性质,只造了这样的测试点:

    所有点权值为 00 或同一个随机权值。然后按照数据范围卡了程序运行效率。

    第三个子任务造法:

    共造 55 组测试点。其中每一组按照程序运行效率来卡,分别有 n=2,3,4,,15n=2,3,4, \cdots, 15n=16n=16T=1000,n=6T=1000,n=6

    第一组测试点中:每一个点都是随机权值,其中随到 00 的概率为 1%1\%,剩下的权值等概率。

    第二组测试点中:每一个点都是随机权值,其中随到 00 的概率为 99%99\%,剩下的权值等概率。

    第三组测试点中:除第一层外,每一层随机将左半边或右半边的结点权值全部设置为 00,剩下半边随机权值。

    第四组测试点中:每个点的权值很小,并且从根节点开始,对每个没有赋予权值的点进行随机游走,本次游走遍历到的点全部赋予一个相同的权值。

    第五组测试点中:造法不予公开。

    可能还是放过了一些错解。在此谢罪。

    信息

    ID
    31
    时间
    1000ms
    内存
    512MiB
    难度
    10
    标签
    递交数
    245
    已通过
    19
    上传者