03 2016 档案
摘要:首先要将这个图连通,方法是通过扫描线+set求出每个连通块最高的点上方的第一条边,然后向交点连边。 然后把边拆成两条双向边,每次找到一条没走过的边,找到极角排序后它的反向边的后继,直到回到这条边。 根据叉积可以求出面积,如果面积非负,那么就说明找到了一个封闭区域。 然后再进行一次扫描线,找到一个点上
阅读全文
摘要:首先将坐标离散化,因为区间互不包含,可以理解为对于每个起点输出最少需要多少个战士。 将环倍长,破环成链,设表示区间左端点不超过时右端点的最大值,可以通过递推求出。 那么如果将看成的祖先的话,它实际上形成了一棵以为根的树。 首先暴力计算出1号点的
阅读全文
摘要:最大流=最小割,而因为本题点的度数不超过3,所以最小割不超过3,EK算法的复杂度为。 通过分治求出最小割树,设表示最小割为时,点在第次分治过程中是否与连通,为的hash值,那么如果$h[k][i
阅读全文
摘要:二分答案,没有出现过的时刻没有用,可以进行离散化。 首先如果某个时刻出现多个人数,那么肯定矛盾。 然后按时间依次考虑,维护: :剩余可选人数。 :现在必定有的人数。 :往左延伸的人数。 :往右延伸的人数。 如果现在有人必须加入,那么优先踢掉的人。 如果当前人多了,
阅读全文
摘要:首先如果一段连续子序列里没有任何幸运数,那么显然可以缩成一个点。 设幸运数个数为,那么现在序列长度是的,考虑暴力枚举,然后从右往左枚举。 每次碰到一个幸运数,就将它删去,维护出被删的数它左边右边连续能到的位置,然后用组合数计算贡献。 考虑给每个被删数字一个删除时
阅读全文
摘要:如果一个区间包含另一个区间,那么这两个区间是否在一起的生产率是一样的。 将所有这种包含了其他区间的区间放入数组,其余的放入数组,有多个相同的时候则从移一个到。 那么里所有区间左端点递增,右端点也递增,设为中前个区间划分成组的最大收益,
阅读全文
摘要:最小值肯定是把树看作二分图,此时答案为。 最大值一定是选取重心为根,任意一个子树要么全部指向根,要么全部背离根,这样可以制造最大的星型图。 统计出每个子树的大小后做01背包,如果小于,那么二进制拆分,否则这种子树不超过个,直接DP即可。 用bitse
阅读全文
摘要:暴力搜索出所有可行的形状,可以发现本质不同的形状数只有6000个左右。 对于每个形状,它的大小不超过,故可以按照右下角为原点重建坐标系,用一个unsigned long long来存储。 然后对于每个中心,先进行第一步扩展,若能成功扩展,则扫描所有形状,看看是否匹配即可。 时间
阅读全文
摘要:枚举左端点,那么可行的右端点的最小值单调不下降,可以通过双指针求出,检验可以通过在后缀数组里检查相邻height值做到。 那么左端点为,右端点在,它对前面一段的贡献为定值,对后面一段的贡献为等差数列,线段树维护即可。 时间复杂度。
阅读全文
摘要:本题就是求重复数最多的字典序最小的,如果重复数为1,那么做法显然,然后只考虑重复数大于1的情况。 从小到大枚举长度,对于每个关键点,有且仅有一个长度为的串经过它。 算出与的最长公共前缀和最长公共后缀后,贡献
阅读全文
摘要:对于每种颜色,可以发现可以切的位置被分割成了若干段独立的区域。 给每个区域一个编号,将种颜色的情况当成字符串来看,如果两个切口的字符串完全匹配,那么可以在这里切两刀。 可以构造hash函数,通过差分前缀和做到修改。 然后对于每一种相同的hash值,将切口按位置从小到大排序,通过组合
阅读全文
摘要:两遍树形DP求出每个点开始往上往下走的前3长路以及每个点上下部分的直径。 枚举每条边断开,设两边直径分别为,则: 对于第一问,连接两边直径的中点可得直径为$\max(A,B,\lfloor\frac{A+1}{2}\rfloor+\lfloor\frac{B+1}{2}\rfloor+1)
阅读全文
摘要:详细做法以及证明请看论文《Hamiltonian paths in the square of a tree》。 首先将1到n的路径提取出来,作为主干。 定义毛毛虫为去掉叶子之后只有一条单链的树,定义non-trivial的毛毛虫为单链非空的毛毛虫。 对于主干上每个点,计算它的非主干部分是否是毛毛虫
阅读全文
摘要:设 表示从向左走,用了不超过天且不回头的最大收益。 表示从向右走,用了不超过天且不回头的最大收益。 表示从向左走,用了不超过天且回到的最大收益。 表示从向右走,用了不超过天且回到的最大
阅读全文
摘要:将分组计划按照从小到大排序,维护一个单调栈,每个元素为一个矩形,按最底下元素从高到低排列,栈顶最低。 每次加入一个矩形可选区域,维护单调栈,可以往回合并。 然后将所有最低点不满足的矩形取出,合并后放回。 每次考虑栈顶区域,将它取到和下一个矩形底边一致时合并。 可持久化线段树维护,时间复杂度$O
阅读全文
摘要:如果两个相邻的串可行,那么它们合并后一定可行,所以求出所有可行的串的个数,则。 注意特判整个串不可行的情况,这个时候答案为0。 #include<cstdio> int n,m,i,t,ans;char a[300010]; int main(){ for(scanf
阅读全文
摘要:找到一棵dfs搜索树,给每条非树边一个随机非0权值,每条树边为所有经过它的树边的权值的异或。 那么有2种情况是合法的: 1.一条边权值为0,一条边权值非0。 2.两条边异或和为0。 排序后统计即可,时间复杂度。 #include<cstdio> #include<algori
阅读全文
摘要:以根为原点,所有叶子为汇点建立网络。 对于一条边,向连边,容量,费用0,再连边,容量,费用1。 然后不断增广,直到费用达到为止的最大流即为答案。 考虑用树链剖分+线段树来模拟这个过程: 首先加入所有费用为0的边,每次求出到根距离最小的可增广的叶
阅读全文
摘要:从上到下枚举下底边,维护表示向上延伸多少距离里面没有坏点,表示向上延伸多少距离里面最多只有1个坏点。 设表示以为最小值,往左往右能延伸到哪里,表示以为最小值,往左往右能延伸到哪里。 枚举$
阅读全文