带着悲伤的心情来上今天的课TAT
今天都是杂题,下午又是要考试了。
没什么心情考试怕不是要爆零。
还是讲了昨天没有讲完的东西。
有下界的网络流。
思想:在做网络流之前,先对这个图改变,一条带下界的边 [L,R] ,拆成一条容量为 L ,一条容量为 R−L 。
我们要让这个 L 的边满流。为了满足流量平衡,所以新建一个源,新建一个汇,由这个新源向 u 连一条为容量为 L 的边,由 v 向新汇连 L .最后从原 T 向原 S 连INF边(这个是为了保证流量平衡)。
可以求最小可行流,最大可行流。
最小可行流就是在新图中从新 S 向新 T 跑最大流满流。记答案 ans ,这里跑出了所有和下界有关的流量。这个满流怎么判断呢?其实就是原 S 到原 T 的那条容量INF边的流量。
最大可行流计算的关键在于应该算出的是“增量”。因此我们可以删去新源新汇,然后在这个图中跑一个最大流(有下界的边保持 R−L )。
接下来讲一些有意思的东西233
以下内容纯属hzc个人经验,仅供参考。
hzc——考试策略的人生经验
从入门到进队——敲出所有暴力(暴力指简单题AC,难题尽可能水)
这个怎么做呢?我们拿30pt的暴力去拍50pt的暴力,用50pt的暴力去写70pt的暴力,用70pt的暴力去拍100pt的暴力……
不论怎么样都要对拍,所以先上暴力。
巧妙的打表——推式子时可以暴力算小数据系数,手推方程组。
考试定理
如果一个价值 x 分的暴力可以在 x 分钟内写完,你就应该写它。
证明
一场考试有5h,即30min
一场考试3道题,满分300分
如果要AK,平均每分钟要拿1分
故成立
考试推论
如果这场考试你的期望得分为 y(y<300) ,那么如果暴力得分有 xy300 ,你就应该去写它( x 为花费时间)。
还有一些很玄学的东西2333
================分割线====================
因为在处理昨晚硬盘爆炸的事情,有两题的讲解我是没有听的,就直接贴ppt了。
西安站的网络赛我是做了的,包括这题(可惜程序都没了)
啊,还是CC的,这题看了一眼博弈论,第二眼看出显然要考虑固定,第三眼就切掉了。不是很懂他们在干什么- -
CC May Lunchtime 2014 - BNGAME
有一排 n 个格子,从左往右编号 1 n ,第 i 个格子里有两个数 ai和bi 玩家初始时站在所有格子左边(0号格子),每次移动玩家可以前进 1 k 个格子,并在停下的那个格子落子。当玩家移出所有格子,即到达 n 号格子右边时,游戏结束。
设落子的格子为 S={p1,p2,…,p|S|} ,则一盘游戏的得分为。
考虑dp怎么转移。
我们需要同时知 a 和 b 的最大值,因此我们必须要枚举 a 的最大值,这样再用一个朴素的 n2 dp看 b 的最小值是多少。
然后这个dp是可以优化的,我们显然可以优化到 O(n) 。
但这样的总复杂度还是接受不了。
考虑枚举 a 的过程中我们可能只需要进行一些小的修改。因此:
CC February Challenge 2014 - LEMOVIE
对于一个序列,定义其激动值为序列中严格大于前面所有数的元素的个数。
比如,{1,1,5,6,5}的激动值为3。
给定 n 个数 p1,p2,…pn ,求这些数的所有排列中,激动值不超过 k 的个数。 1≤k≤n≤200,1≤pi≤200
为了简化问题,我们可以考虑如果没有相同的数应该怎么计算?
令 f[i][j] 表示已经插入前 i 大的数激动值为 j 的方案数。
显然,对于第 i+1 个数对激动值的贡献至多为1,而且只能将这个数插在最前面时才会有贡献。且插在其他位置时,激动值不会减少。
这样的dp方程很容易列出。
那么现在考虑有相同的数,我们将相同的数分为一组。
根据经验,我们发现这组数对激动值的贡献至多也为1,而且当且仅当至少有一个数被插在了最前面。且插在其他位置时,激动值不会减少。
假设已经插入了 x 个数,现在这组有 y 个,那么没有一个数被插在最前面的方案数是:
考试日,T1出题人丢给你一堆文字,然后让你猜这是什么数据结构,猜完了就大概知道怎么做了。(猜了半小时)
T2数学题,不会,打暴力。(事实上刚开始题目都没看懂)
T3简单题,随便敲一敲。
然后T3只用了25min,敲完正解+对拍,一点也不虚。去搞T1,用2h写完,很愉快地过了样例,然后打暴力对拍后发现写挂了,遂调试,然后用1h调出来。
最后一点时间想T2,想着100+20+100稳了啊,然后出来T3RE了。
什么?RE?。
发现读入少了一个取地址符。原来肯定是有的啊,不然会报错的???
郁闷,又没有东西拿了。
先讲了一下考试的题目,发现T2原来就是个容斥原理,啊,还是我太蒻了都不会推式子了。
没想到三题都是原题。(早知道去AK了)
然后是继续上一些杂题。
上午最后CC的那题还有EXTRA,将激动值的定义改成了序列中相邻且构成逆序对的个数。
做法类似。
从小到大考虑,此时插入一个数可能会抵消之前的激动值。
枚举有几个数插在原来的非逆序对之间,可以类似地算出方案数。
复杂度 O(nk2) 。
July Cook-Off 2014-RRTREE2
Tree Again
给点 n 个点的有根数,1号点为根,每个节点有权值 wi 。
我们称一个数 S 合法,当且仅当存在一个 1 n 的排列 p ,
使得 p 为这棵树的某个DFS序,且存在 1≤k≤n 使得
CC January Challenge 2014 - FRBSUM
ForbiddenSum
定义一个多重集 S 的ForbiddenSum为,不能表示为S的某个子集中所有元素之和的最小元素。
比如,多重集{1,1,3,7}的ForbiddenSum为6。
给定长度为 n 的序列 a ,有 m 次询问,每次给定 li,ri ,询问多重集 S={al,al+1,…,ar} 的ForbiddenSum。 n,m≤105,∑ai≤109
在翻译题面的我如此颓废,不过这是好题啊。
考虑如果给定这个集合我们怎做?
最后是这题:
CC March Challenge 2014 - GERALD07
忘记它了?——已经在这些天的blog里出现第四次了。
它叫这个名字——Chef and Graph Queries
溜了溜了。
今天的考试真的好菜啊。
莫名RERERERERERE。
BZOJ还BZ了,题目都刷不了了TAT。