疯狂的重心

话说做过幻想乡战略游戏的人应该很容易切掉这道题目吧

我们考虑一棵树如果添加了一个叶子,那么其重心最多向叶子方向移动1的距离

而是否移动我们只需要记录子树中有多少个点就可以判断啦

也就是说这个叶子对于时间复杂度的贡献是1

那么我们考虑每次在x-y上添加一条边,等于将x所在的树和y所在的树合并

这一步我们可以采用启发式合并,每次把小的向大的里插

这样暴力合并的时间复杂度是O(nlogn)

也就等价于我们最多插入单个节点O(nlogn)

那么对于重心的计算显然也是O(nlogn)的

那么现在的瓶颈就是如何动态的维护子树中有多少个节点

对于这一步我们可以采用LCT维护,每次暴力合并之后链修改即可

在合并之后再暴力移动重心就可以辣,细节比较多也比较烦

不过主体都是暴力QAQ

疯狂的机器人

做了做BC上周的题目,有个裸的默慈金数

可以直接O(n)递推得到,做完之后一直想着能不能用FFT搞一搞

然后就把题目变了个形,但是并不知道有没有大神有O(n)递推的神做法

首先我们考虑操作中哪些操作走,设走的操作有i个

再考虑走的操作中哪些是向上走,设向上走的操作有j个

我们很容易发现当只能向右和向左走时,这个题实际上是合法进出栈序列,也就是卡特兰数

只能向上和向下走的时候也同理

很容易得到ans=sigma(C(n,i) *sigma( C(i,j) * f(j) * f(i-j)))

其中f(i)我们定义为当i为奇数时,f(i)=0

当i为偶数时,f(i)=catalan(i/2)

令g(i)=sigma(C(i,j) *f(j) *f(i-j))

不难发现这是个卷积形式,直接NTT即可

之后ans=sigma(C(n,i) *g(i) )

我们这一步直接枚举i计算其实就可以了

不过实际上这还是个卷积形式,依然可以NTT

cojs 疯狂的重心 疯狂的机器人 题解报告的更多相关文章

  1. cojs 疯狂的粉刷匠 疯狂的斐波那契 题解报告

    疯狂的斐波那契 学习了一些奇怪的东西之后出的题目 最外层要模p是显然的,然而内层并不能模p 那么模什么呢,显然是模斐波那契的循环节 那么我们可以一层层的求出每层的斐波那契循环节 之后在从内向外用矩阵乘 ...

  2. cojs 强连通图计数1-2 题解报告

    OwO 题目含义都是一样的,只是数据范围扩大了 对于n<=7的问题,我们直接暴力搜索就可以了 对于n<=1000的问题,我们不难联想到<主旋律>这一道题 没错,只需要把方程改一 ...

  3. cojs 二分图计数问题1-3 题解报告

    OwO 良心的FFT练手题,包含了所有的多项式基本运算呢 其中一部分解法参考了myy的uoj的blog 二分图计数 1: 实际是求所有图的二分图染色方案和 我们不妨枚举这个图中有多少个黑点 在n个点中 ...

  4. 2015浙江财经大学ACM有奖周赛(一) 题解报告

    2015浙江财经大学ACM有奖周赛(一) 题解报告 命题:丽丽&&黑鸡 这是命题者原话. 题目涉及的知识面比较广泛,有深度优先搜索.广度优先搜索.数学题.几何题.贪心算法.枚举.二进制 ...

  5. 题解报告:hdu 1398 Square Coins(母函数或dp)

    Problem Description People in Silverland use square coins. Not only they have square shapes but also ...

  6. 题解报告:hdu 2069 Coin Change(暴力orDP)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2069 Problem Description Suppose there are 5 types of ...

  7. 题解报告:hdu 1028 Ignatius and the Princess III(母函数or计数DP)

    Problem Description "Well, it seems the first problem is too easy. I will let you know how fool ...

  8. CF Educational Round 78 (Div2)题解报告A~E

    CF Educational Round 78 (Div2)题解报告A~E A:Two Rival Students​ 依题意模拟即可 #include<bits/stdc++.h> us ...

  9. CF1169(div2)题解报告

    CF1169(div2)题解报告 A 不管 B 首先可以证明,如果存在解 其中必定有一个数的出现次数大于等于\(\frac{m}{2}\) 暴力枚举所有出现次数大于等于$\frac{m}{2} $的数 ...

随机推荐

  1. iOS人机界面指南(翻译)

    本文源自于苹果开发者网站的文章iOS Human Interface Guidelines,内容比较多,此处仅仅是部分笔记.

  2. php session偶尔写入失败的原因

    session_start(); var_dump($_SESSION); $key = sprintf('%05d', mt_rand(0, 99999)); $key = strval($key) ...

  3. google查询技巧

    技巧一:使用正确的方法 无论你是使用一个简单或是高级的Google搜索,在此都存在你应该使用的某种可靠的方法.遵循适当的方法你就能获得非常准确的结果:要是忽略这条建议的话,你也许就会看到大量不相关的结 ...

  4. ActiveMQ之JMSReplyTo

    在下面的例子中,首先创建两个Queue,发送者给一个Queue发送,接收者接收到消息之后给另一个Queue回复一个Message,然后再创建一个消费者来接受所回复的消息.import javax.jm ...

  5. tomcat中server.xml文件解析

    下面我们将讲述这个文件中的基本配置信息,更具体的配置信息见tomcat的文档 元素名 属性 解释 server port 指定一个端口,这个端口负责监听关闭tomcat的请求 shutdown 指定向 ...

  6. C# 清楚Cookies

    //销毁Cookies中的数据 if (Request.Cookies["Ticket"] != null) { HttpCookie mycookie; mycookie = R ...

  7. 问题 K: 【USACO2012Feb】植草 {Bronze题2}

    按着矩形周长的思路,到当前边的时候,前一层的覆盖数乘以高度加入 ans 就行,然而真正的算法可能并不是这个..只能想到这个了 ; type node=record l,r,mid,sum,delta: ...

  8. iOS常见问题(2)

    一.模拟器黑屏 解决方法: 二.打代码时,Xcode没提示 解决方法: 0. 点击Preferences 1. 进入Text Editing 2. 勾选 三.有时候可能在勾选 Autolayout的时 ...

  9. busying

    罪过 ,最近好忙  ,好久没有发表东西了, 连英语单词都写错了

  10. duilib中各控件响应的消息类型

    消息 说明 Sender click 鼠标点击 CButtonUI dropdown 下拉显示 CComboUI headerclick 点击列标题 CListHeaderItemUI itemact ...