03 2018 档案

摘要:点分治+cdq分治 一看就是斜率优化,可惜在树上 有一个比较显然的方法是树链剖分凸包 但是复杂度较高 然而这道题可以用cdq分治 每次树分治的时候先处理朝向根的链的值 然后再更新儿子 #include <cstdio> #include <cstring> #include <algorithm> 阅读全文
posted @ 2018-03-05 15:41 19992147 阅读(165) 评论(0) 推荐(0) 编辑
摘要:可并堆 对于一段递减的序列我们可以取中位数作为b 那么我们可以把a分成几段递减的序列,每段都取中位数,并且中位数递增 那么维护一个单调栈,每次新加入元素,如果当前段的中位数比之前小就吃掉之前的 中位数用可并堆维护,维护前n/2大的数就行了 #include <cstdio> #include <cs 阅读全文
posted @ 2018-03-05 09:09 19992147 阅读(123) 评论(0) 推荐(0) 编辑
摘要:组合数学 我好菜啊 想到dp去了。。。 事实上对于固定长度的数列,我们只用考虑选了哪些数就行了,所以这个就是$C(n+m-1,m-1)$ 也就是$n$个数,划分成$m$段且允许空的方案数 然后变成$\sum_{i=1}^{n}{C(i+m-1,m-1)}$ 经过popoqqq的推导方法 我们得出最终 阅读全文
posted @ 2018-03-04 21:24 19992147 阅读(123) 评论(0) 推荐(0) 编辑
摘要:最短路 很早以前做的了 数据范围太大,不能直接算 mn=min(a[i]) 算出d[i]表示sum%mn=i最小能构成的数,这个用最短路就行了,然后计算d[i],d[i]+mn的个数统计答案 #include<bits/stdc++.h> using namespace std; const int 阅读全文
posted @ 2018-03-04 20:45 19992147 阅读(132) 评论(0) 推荐(0) 编辑
摘要:高斯消元+概率dp 我好纸张 设dp[i]表示i到n异或和为1的概率,那么暴力高斯消元就行了,注意方程中n那一行要清零 #include <cstdio> #include <cstring> #include <algorithm> #include <cmath> using namespace 阅读全文
posted @ 2018-03-04 19:00 19992147 阅读(116) 评论(0) 推荐(0) 编辑
摘要:lct+SAM bzoj4516+bzoj2555 这道题唯一的用处就是教会了我真正的广义SAM dfs时保留当前节点在后缀自动机中的位置,每个点接着父亲建 lct动态维护right集合大小,用lct维护子树就行了 #include <cstdio> #include <cstring> #incl 阅读全文
posted @ 2018-03-01 09:11 19992147 阅读(216) 评论(0) 推荐(0) 编辑