自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+

CE玩家

人生最大的快乐,就是做别人说你做不到的事。

原创 AFO

2018.7.20 苟不下去了。 下午查成绩T1炸成50分的时候就知道自己已经翻不了盘了。 最后知道队线452的时候真是绝望。 要是day1T2写了卡特兰数或者day2T1对拍一下就稳了吧。 …...

2018-07-20 22:51:14 1271 5

原创 [Min-Max 容斥] LOJ#2542. 「PKUWC 2018」随机游走

这题我原来使用 O(2nn3)O(2nn3)O(2^n n^3) 暴力过的…跑的还贼快 可以用Min-Max 容斥 设 Max(S)Max(S)Max(S) 表示集合里最晚被访问的节点被访问的期望步数(也就是访问所有节点的期望步数)。 设 Min(S)Min(S)Min(S) 表示集合里最早...

2018-05-24 18:29:11 1063 0

原创 [容斥 NTT] LOJ#2541. 「PKUWC 2018」猎人杀

很妙的题 这题其实如果不考虑攻击的限制,也就是不管猎人死没死,他都能被当作攻击的目标,一个猎人被攻击到的概率是一样的。 设 A=∑wiA=∑wiA=\sum w_i , BBB 为以及死的猎人的 wiwiw_i 的和,设 PiPiP_i 为 iii 是下一个被杀死的概率(iii 之前还活着)...

2018-05-13 10:39:01 1148 0

原创 [DP] LOJ#2473. 「九省联考 2018」秘密袭击

设 fifif_i 表示选出的联通块第 kkk 大的值大于等于 iii 的方案数 那么答案就是 ∑wi=1i(fi−fi+1)=∑wi=1fi∑i=1wi(fi−fi+1)=∑i=1wfi\sum_{i=1}^w i(f_i-f_{i+1})=\sum_{i=1}^w f_i 枚举 iii,把...

2018-04-07 21:36:23 380 0

原创 [贪心 线段树] LOJ#2472. 「九省联考 2018」IIIDX

从1到n枚举,逐位确定。 首先可以把关系树建出来,一个点的权值要大于等于父节点的权值。 如果没有相同数字的,第 iii 以及它子树种的点会选择 [n−sizei+1,n][n−sizei+1,n][n-size_i+1,n] 这个区间里的数,选完后把这个区间删去,继续考虑 i+1i+1i+1 ...

2018-04-07 21:29:41 333 0

原创 [博弈] LOJ#2471. 「九省联考 2018」一双木棋

考虑暴力。 每次枚举放哪个位置,设已经放了棋子的位置集合为 SSS,fSfSf_S 表示当前放置情况为 SSS 时,双方采用最优策略后,两个人的权值和的差。 那么如果是菲菲,会选择 fS+ai,jfS+ai,jf_S+a_{i,j} 最大的,牛牛会选择 fS−bi,jfS−bi,jf_S-b_...

2018-04-07 21:16:17 244 0

原创 [杂题] hihocode1715. 树联通问题

考虑计算每条树边出现在哪些区间了,但是这样不太好统计,补集转换一下计算每条树边没有出现的区间的个数 那么用set维护一下每棵子树中的点的标号,如果一个区间里的元素都不在这个set里或者都在这个set里,那么这个点到父亲的边都不在这个区间里 启发式合并一下就可以了 #include &...

2018-03-28 22:08:02 219 0

原创 [容斥 状压DP] Atcoder ARC093 F - Dark Horse

wwwww比赛的时候题目看错了 假设我们确定的1的位置,那么接下来的每一轮,1都会和一段长度为2的幂的区间里,标号最小的人pk。 把1固定在1位置(求出最终方案数后乘上 2n2n2^n 就是答案),那么就相当于区间 [2,2][2,2][2,2],[3,4][3,4][3,4],[5,8][5...

2018-03-26 08:32:51 515 0

原创 [补集转换] Topcoder SRM563 DIV1. CoinsGame

枚举两个点,如果经过一系列操作使得一个留在棋盘上一个不在,那么这个点对是有价值的 那么合法的放棋子的方案一定包含至少一个有价值的点对 但是点对个数是 O((nm)2)O((nm)2)O((nm)^2) 的,直接容斥不行 补集转化一下,可以发现如果点对 (a,b)(a,b)(a,b) 和点对 ...

2018-03-24 13:58:12 210 0

原创 [DP] Topcoder SRM 562 DIV1. InducedSubgraphs

分类讨论 当 2k≤n2k≤n2k\le n 时,两边是树中间是一条链,枚举链然后DP 当 2k>n2k>n2k>n 时,中间部分为一个联通块,这个联通块一定过重心,求出重心后DP #include <cstdio> #inclu...

2018-03-24 13:51:31 201 0

原创 [树的直径] Codechef March Cook-Off 2018. Maximum Tree Path

这个套路好像是计蒜之道里的一题 考虑枚举gcd 把两端点都是gcd的倍数的边存下来,按照两段点较小值从大到小排序 枚举每一条边,把这条边加入图中,可以用并查集维护出所有联通块的直径,然后就好了 #include <cstdio> #include &...

2018-03-23 21:14:30 167 0

原创 [期望] Topcoder SRM561 Div1 1000. Orienteering

首先每条边至多走两遍,可以选出一条最长的链,这条链上的所有边走一遍,其他边走两边。 那么答案就是 2|E|−|P|2|E|−|P|2|E|-|P| 其中 EEE 是边集,PPP 是最长的链 这个的期望就是 2E(|E|)−E(|P|)2E(|E|)−E(|P|)2E(|E|)-E(|P|) ...

2018-03-23 14:49:58 128 0

原创 [数学] Topcoder SRM560 Div1 1000. BoundedOptimization

可以枚举每个元素的值是上界、下界还是中间值,总共有 3n3n3^n 种情况 若存在两个元素 xi,xjxi,xjx_i,x_j,它们都取中间值,且xixjxixjx_ix_j 不在式子中, 那么设表达式为 axi+bxj+caxi+bxj+cax_i+bx_j+c,可以发现最有情况肯定是 xi...

2018-03-23 11:59:49 151 0

原创 [DP] LOJ#6307. 「雅礼国庆 2017 Day1」Clique

假设 xi>xjxi>xjx_i>x_j 那么 iii 和 jjj 之间有边的条件是 xi−xj≥wi+wjxi−xj≥wi+wjx_i-x_j\ge w_i+w_j 把一个点看作一个区间 (xi−wi,xi+wi)(xi−wi,xi+wi)(x_i-w_i,...

2018-03-20 11:02:59 178 0

原创 [二分 bfs] UOJ#371. 【UR #17】滑稽树下你和我

二分答案 用点对 (x,y)(x,y)(x,y) 表示一个人在 xxx,另一个在 yyy 的状态,当 xxx 和 yyy 的距离小于等于二分的答案时,这个状态合法。 两个状态 (x1,y1)(x1,y1)(x1,y1) 和 (x2,y2)(x2,y2)(x2,y2) 直接相连,当且仅当 x1x...

2018-03-19 12:27:18 283 1

原创 [Contest] CodeChef March Challenge 2018

听说CC也分div1 div2了 Mix the Colors 如果有重复的数,就把最大的数加到这个数上,所以答案是n减去不同的数的个数 Chef and Easy Problem 从高到低枚举贪心。 Minions and Voting 对每个人二分一下它能投票的区间 Che...

2018-03-15 13:22:09 181 2

原创 [线段树 博弈] 一道博弈题

障碍点数和询问点数都是1e5 坐标范围为1e9(实际数据既然有大于1e9的) 一个点的下方或左边存在必败点,则为必胜点,否则为必败点 同一行的障碍会把这一行分成很多段,段与段之间是互不影响的。 考虑同一段的点,若其中一个点为必败点,则之后的点一定是必胜点,也就是说要找到第一个必败点 扫...

2018-03-15 10:41:14 177 0

原创 [数位DP] 【UNR #2】梦中的题面

当 c=1c=1c=1 的时候,很容易想到转成 bbb 进制 每一位独立考虑,就可以数位DP了 当 c=0c=0c=0 的时候,再加一维表示之前满足 xi=bixi=bix_i=b^i 的个数就可以了 #include <cstdio> #include &...

2018-03-14 10:04:26 271 0

原创 [DP] 【UNR #2】积劳成疾

fi,jfi,jf_{i,j} 表示长度为 iii 最大值为 jjj 的序列的答案 枚举最大值的位置转移就好了 #include <cstdio> #include <iostream> #include <algori...

2018-03-14 09:58:48 141 0

原创 [回文串 线段树] Codeforces Gym100032 ICL Cup 2012 K. Subpalindromes

题意是求一个区间里回文串的个数(出现位置不同的回文串算不同) 用马拉车算出以每个点为中心的最长回文串长度 考虑点 iii,iii点到以它为中点的最长的回文串的端点长度为 xxx 那么它对一个询问的贡献是 min{i−L,R−i,x}min{i−L,R−i,x}\min\{i-L,R-i,x\...

2018-03-11 19:14:16 232 1

原创 [随机构造] UOJ#76. 【UR #6】智商锁

随机1000张25个点的图,two-points枚举所有情况 #include <cstdio> #include <iostream> #include <algorithm> #include &...

2018-03-10 15:54:17 326 1

原创 [决策单调 分治] LOJ#535. 「LibreOJ Round #6」花火

如果 i<ji<jiai>ajai>aja_i>a_j 那么 iii 作为左端点比 jjj 优,右端点同理 那么搞出两个上升序列,发现右端点递增的时候左端点也是单调上升的,也就是gjghfd和v...

2018-03-09 13:30:13 601 2

原创 [三元环] BZOJ5206: [Jsoi2017]原力

活那么久竟然都不会找三元环… https://www.cnblogs.com/jiachinzhao/p/7474761.html 这题的话,颜色相同且两端点相同的边权值可以加在一起,然后找三元环就好了 #include <cstdio> #include &am...

2018-03-09 09:03:50 543 0

原创 [最小割] Topcoder SRM558Div1. SurroundingGame

对网格黑白染色 黑的格子和源点连边,白的格子和汇点连边 因为如果保留benefit就必去删去cost或者所以和他相连的格子的cost 大概是这样 跑最小割 #include <cstdio> #include <iostream&...

2018-03-08 18:40:45 234 0

原创 [网络流] BZOJ3894 文理分科

经典模型我都不会 每个点拆成三个点,分别表示“选文理”“周围的人都选文科”“周围的人都选理科” 然后根据关系连边 #include <cstdio> #include <iostream> #include <algori...

2018-03-08 18:29:14 150 0

原创 [线性基 贪心] Topcoder SRM557Div1. XorAndSum

对数列建线性基,求出最大异或值 那么不在线性基里面的元素可以把它变成最大异或值 在线性基里的元素,可以把最高位的元素变成最大值,然后把其他数异或上最大值 #include <cstdio> #include <iostream> #...

2018-03-08 15:45:00 331 0

原创 [网络流] Topcoder SRM556DIV. OldBridges

只有一个人的时候,可以把图建出来看是否满流 但是两个人的时候会出现特殊情况 把b1和b2反过来在跑一遍就好了 #include <cstdio> #include <iostream> #include <algo...

2018-03-08 14:51:58 306 0

原创 [容斥] Topcoder SRM555DIV1. MapGuessing

经典题了 枚举初始状态的磁头位置,求出哪些位置可以随意改动,然后大力容斥 #include <cstdio> #include <iostream> #include <algorithm> #includ...

2018-03-08 07:53:42 149 0

原创 [Tarjan] BZOJ5201: [NEERC2017]Connections

tarjan的时候每次每次加入一条返祖边,都会至少缩去一个点,那么只要记录一下遍历过的边以及返祖边就可以了 #include <cstdio> #include <iostream> #include <algorithm...

2018-03-07 19:59:35 329 0

原创 [矩阵乘法优化DP] Topcoder SRM554. TheBrickTowerHardDivOne

dp fi,sfi,sf_{i,s} 表示第 iii 层的状态为 sss 的方案数 转移是一个矩乘的形式 用矩乘快速幂优化 #include <cstdio> #include <iostream> #include &l...

2018-03-07 18:58:39 152 0

原创 [差分约束] Topcoder SRM553 Div1 Hard. YamanoteLine

可行的长度肯定是一个区间 约束条件可以建城差分约束系统,那么判无解就是判是否有负环 记一下负环上关于总长度的系数,二分就可以了 #include <cstdio> #include <iostream> #include &...

2018-03-07 13:23:13 236 0

原创 [启发式分裂] BZOJ5200 [NWERC2017]Factor-Free Tree

当找到一个根的时候会把区间分成两个部分,然后递归做 问题就是怎么找根了 可以用bzoj4059那种思路,大概叫启发式分裂吧 对每个数,可以预处理一下在它左边第一个与他不互质的数和在它右边第一个与它不互质的数 然后就 O(nlogn)O(nlog⁡n)\mathcal{O}(n\log n)...

2018-03-07 08:28:27 559 0

原创 [多项式exp] LOJ#556. 「Antileaf's Round」咱们去烧菜吧

学一发分治FFT求多项式exp 感觉这种打法应该比牛顿迭代好打多了 #include <cstdio> #include <iostream> #include <algorithm> using names...

2018-03-06 10:47:33 336 0

原创 [二分图] 【JOI2017春季合宿】Port Facility

T2比T1可做多了… 每个玩具相当于一条线段,交叉的线段之间连边,就变成求二分图染色的方案数 考虑怎么建边 把左端点排序,右端点用set维护,假设现在加入的线段为(l,r) 因为有三元环就直接无解了,所以当前所有右端点比r小的线段都是相互包含的,否则就无解 而这时候这些线段之后染色的颜色...

2018-03-06 09:04:40 386 0

原创 [DP] Codeforces 936D. World of Tank

令 fi,jfi,jf_{i,j} 表示走到 (i,j)(i,j)(i,j) 时的最大充能 坐标离散后 O(n)O(n)O(n) DP一下就好了 #include <cstdio> #include <iostream> #include...

2018-03-05 16:55:12 295 0

原创 [链剖 FFT] LOJ#6289. 花朵

树形DP的转移是一个卷积的转移形式 可以先链剖,一个点的轻儿子先合并,然后一条重链用分治FFT合并 #include <cstdio> #include <iostream> #include <algorithm&am...

2018-03-05 10:34:14 270 0

原创 [eertree] Codeforces 932G. Palindrome Partition

http://codeforces.com/blog/entry/19193 不是很懂证明 #include <cstdio> #include <iostream> #include <algorithm> ...

2018-03-05 10:31:47 448 0

原创 [Bluestein's Algorithm DFT] Codechef REALSET. Petya and Sequence

A和B的运算是卷积形式 考虑把A和B DFT D(A)∗D(B)=0,D(B)≠0D(A)∗D(B)=0,D(B)≠0D(A)*D(B)=0 , D(B)\neq0 也就是 A DFT后至少有一个0 求出模某个质数意义下的 2n2n2n 次单位根 用Bluestein’s Algorit...

2018-03-01 16:46:25 214 0

原创 [DP 博弈] Topcoder SRM579 Div1. RockPaperScissors

每一轮的策略跟之前出现过的剪刀石头布的数量有关 另 fi,a,b,cfi,a,b,cf_{i,a,b,c} 表示之前出现了 aaa 次石头, bbb 次剪刀 ,ccc 次布,然后第 iii 个筛子没用过的概率 DP一下,每一轮独立算贡献 // BEGIN CUT HERE // END...

2018-02-28 11:12:04 119 0

原创 [卷积定理] LOJ#548. 「LibreOJ β Round #7」某少女附中的体育课

设变换矩阵为 TTT 由卷积定理可以知道 对于 TTT 的每一行的任意 i,ji,ji,j 满足 xi×xj=xi opt xjxi×xj=xi opt xjx_i\times x_j = x_i ~\text{opt}~...

2018-02-26 10:40:25 298 0

提示
确定要删除当前文章?
取消 删除