UOJ Logo hos_lyric的博客

博客

#793. 【UR #24】比特智慧 another? solution

2023-06-02 05:35:00 By hos_lyric

Hello UOJ! 非常感谢 UOJ community for the great contests!!

I present a solution which is kind of a combination of the above two, so it might be essentially the same with them, but I hope it contains something valuable (e.g. easier to come up with).

First of all we need the very clever correspondence to the forest problem, described in 算法二点五 of the editorial.

To count the coloring ways, we can assign weight to each 道路 (thus to each edge), with the base answer km+1. The weight depends on the number of non-final 接口s among the two 接口s created on the 道路. Letting this number be q{0,1,2}, the weight aq is a0=11k,a1=12k,a2=12k3k(k1). These are based on the fact that k colors are symmetric. Through the correspondence, q for edge {u,v} is the number of satisfied conditions among the following:

  • w s.t. edge {u,w} exists and w is on the arc from u to v clockwise.
  • w s.t. edge {v,w} exists and w is on the arc from v to u clockwise.

correspondence.png

Now let's count the trees. We define two GFs (with x counting the vertices) for the following cases:

  • f: The root will be attached to a parent which becomes the final 接口.
  • g: The root will be attached to a parent which becomes the non-final 接口.

For the whole tree, we can fix a root then its children are nothing or f,g,,g, so the GF we want to find is h=x(1+f1g).

whole tree

And we formulate the recurrence by noticing that the edge to the parent will separate the region into two parts:

f=x(a0+a1f1g)11gg=x(a1+a2f1g)11g

recurrence

Solving the second one in f and plugging it into the first one gives an equation in g of degree 5, so we can apply the Newton method... In fact we can be lazy here because these behave well for online convolution ([xn]f or [xn]g on the left-hand side is determined by fmodxn and gmodxn on the right-hand side), so f and g can be calculated in O(nlog(n)2) time. The implementation is easy with fjzzq2002's cool template https://fjzzq2002.blog.uoj.ac/blog/7281 (sorry I am so lazy to just copy it...).

Then we can find h, and finally the answer for the forest case is (magically) 1n+1(n+1nm)[xn]hnm; This is well explained in zhoukangyang's solution.

My submission: https://uoj.ac/submission/625385

I wonder if the equations above for f and g can lead to a simpler/faster algorithm like zhoukangyang's.

By the way, this solution is relatively simple if we just want to count the trees without considering the coloring (i.e. when aq=1): since f=g we have f=x1(1f)2. By Lagrange inversion, [xn+1]h=[xn]11f=1n[xn1](11x)(1(1x)2)n=1n[xn1]1(1x)2n+2=1n(3nn1) and this agrees with https://oeis.org/A001764.

hos_lyric Avatar