码迷,mamicode.com
首页 > 其他好文 > 详细

ur c题练习

时间:2016-04-20 23:19:25      阅读:167      评论:0      收藏:0      [点我收藏+]

标签:

ur的c果然sxbk啊

ur2:有根树分治裸题,复杂度玄学$O(n\sqrt{n})$。

首先,转化为统计k的倍数的个数。

经过重心C的路径分两种情况:(设n为当前树的大小)

1、在C的子树中,直接O(n)计算;

2、一个在C的子树中,另一个不在,则枚举路径的lca=p,计算出p的不在C到当前分治结构的根的路径上的孩子的子树中深度为每个数的倍数的个数,再计算C的孩子到p的长度为p倍数的个数。考虑算法复合,若当前枚举的深度d小于 $\sqrt{H}$那么记忆化,否则直接暴力在C的子树中找深度符合要求的点的个数,复杂度$O(n\sqrt{n})$。

根据主定理,总复杂度$O(n\sqrt{n})$。随便写写居然在uoj上时间rank1。。。

ur c题练习

标签:

原文地址:http://www.cnblogs.com/shanquan2/p/5414626.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!