2019暑期金华集训 Day3 图论
自闭集训 Day3
图论
NOI2019 D2T1
没有真正建出图来的必要,可以直接打取\(\min\)的\(tag\)。
也可以把边压进堆里,然后变成一个二维清点问题(???),然后就线段树+并查集(???)。
POI 2014/2015 某题
类似于GDOI2019,线段树或者堆直接做。
Gym101372 E
首先肯定要缩点。
给每个点赋一个随机权值,然后把每一个点的权值更新成能到的所有的点权值的min。
由于\([0,1]\)的\(n\)个随机权值的\(\min \)期望是\(\frac 1 {n+1}\),而我们现在已经知道了\(\frac 1 {n+1}\),于是可以解出\(n\)。
多做几遍取平均,就做完了。
SD省队集训 D1T1
首先,把每一条边都取一遍,但这样可能会使得某些点度数为奇数,不存在欧拉回路。
于是问题就变成给一个01串,有一些边可以使得两个点的权值都异或1,问把所有点的权值都变成0的最小代价。
由于边权很特殊,就可以直接做最小生成树(或者二分最大的权值然后瞎搞应该也可以)。
Hihocoder Challenge 28
考虑魔改Matrix Tree定理。
给每一条边的权值设成一个多项式:
\[
\sum_{i=0}^k w^i \frac 1 {i!} x^i
\]
然后直接插值就没了。
最小方差生成树
首先发现\(f(\sigma)=\sum_{i=1}^{n-1} (\sigma -w_i)^2\)必定在\(\sigma\)取到平均值的时候取到最小值,所以可以枚举\(\sigma\)然后做kruskal。
又发现kruskal只和边的大小关系有关,而大小关系只会变化\(m^2\)次,所以有了一个\(O(m^3\log m)\)的做法。
可以发现,每条边存在于最小生成树的时间一定是一段区间。我们只需要求出这个区间就可以得到答案。
对于一条边\(e\),什么时候才能被加进去?必须要对于每一个包含\(e\)的环上的边的最小值\(w\),都有\(\sigma >(w+w_e)/2\)的时候\(e\)才能被加进去。
什么时候会被删掉?其实也是同理,只要有一个环满足~~~就可以删掉。
所以用LCT动态维护最大生成树搞出\(l,r\),然后按时间跑一遍,就做完了。
某题
首先肯定要二分答案,然后把一个点四周四个小三角形拿出来。这些小三角形要满足对立的两个必须选恰好一个,而有重叠的不能选。
然后就做完了。
TCO Hard
限制等价于三个点两两不在\(Q\)的同一个子树里。
首先把1提为根,记\(f_{x,y}\)表示\(x\)是否在\(y\)的子树里。
于是我们有
\[
f_{x,p}=1\rightarrow f_{x,fa_p}=1\\
f_{x,p}
=0\rightarrow f_{x,son_p}=0\\
f_{x,1}=1\\
f_{x,s1}=1\rightarrow f_{x,s2...k}=0\\
f_{x,Q}=0\rightarrow f_{y/z,Q}=1\\
f_{x,son}=1\rightarrow f_{y/z,son}=0
\]
注意两个人是可以站在同一个位置的。
似乎就没了????
CF547D
掉线……
一开始看错了题,后面才知道原来棋子的位置都是不变的,只是要染色。
考虑把行列看做点,棋子看做边,那么就变成了一个二分图。
先想如果必须黑点白点相同该怎么办。此时每个点的度数都必须是偶数,然后就可以找出某一个欧拉回路的方案,然后把从左到右的边作为黑点,从右往左的作为白点。
如果可以相差1呢?度数是偶数的点还是必须要相等,而奇数的点就较为麻烦。题解给的做法是两边各建一个虚点,奇数的点向对面的虚点连边,如果两个虚点的度数也是奇数那么再互相连边,然后求欧拉回路即可。
某题
首先,如果贡献的不是\(m^2\)而是1,那么大家都会,就是\(2^{非树边条数}\)。
如果贡献的是\(m\),那么就可以枚举每一条边,观察这条边是不是桥边,然后乱搞。
贡献的是\(m^2\),那么仍然枚举两条边强制选。如果两条边里面有边是桥边,那么肯定没了。否则,如果删去两条边连通情况不改变,那么很容易搞。如果改变,那么就多了一个连通快,也很容易搞,但贡献不同了。
所以,我们就是要求有多少对边,使得他们不是桥边,而且删掉之后连通情况不改变。
对于某一对边,如果都是非树边那么显然不变;如果一条树边一条非树边,那么当且仅当那条树边只被那条非树边覆盖的时候连通情况改变;如果两条树边那么当且仅当两条边只被同一条非树边覆盖的时候连通情况改变。
于是有一个神奇做法:对于每条非树边随机一个权值(树边的初始权值为0),然后把它覆盖的这一条树上的链的值全都异或上自己的权值,那么就可以直接数权值相同的边的对数。
然后就没了。
2019暑期金华集训 Day3 图论的更多相关文章
- 2019暑期金华集训 Day3 字符串
自闭集训 Day3 字符串 SAM 考虑后缀树. SAM的parent树是反串的后缀树,所以后面加一个字符的时候相当于往串前面加一个字符,恰好多出了一个后缀. 于是可以以此来理解SAM. 每一条路径对 ...
- 2019暑期金华集训 Day7 分治
自闭集训 Day7 分治 主定理 由于我沉迷调题,这个地方没听课. 某些不等式 咕了 nth_element 使用快速排序的思想,选一个中间点,看左右有多少个. 期望复杂度\(O(n)\). 首先把一 ...
- 2019暑期金华集训 Day7 动态规划
自闭集训 Day7 动态规划 LOJ6395 首先发现这个树的形态没啥用,只需要保证度数之和是\(2n-2\)且度数大于0即可. 然后设\(dp_{i,j}\)表示前\(i\)个点用了\(j\)个度数 ...
- 2019暑期金华集训 Day6 杂题选讲
自闭集训 Day6 杂题选讲 CF round 469 E 发现一个数不可能取两次,因为1,1不如1,2. 发现不可能选一个数的正负,因为1,-1不如1,-2. hihoCoder挑战赛29 D 设\ ...
- 2019暑期金华集训 Day6 计算几何
自闭集训 Day6 计算几何 内积 内积不等式: \[ (A,B)^2\le (A,A)(B,B) \] 其中\((A,B)\)表示\(A\cdot B\). (好像是废话?) 叉积 \[ A\tim ...
- 2019暑期金华集训 Day5 树上数据结构
自闭集训 Day5 树上数据结构 前置知识 点分治 边分治 树链剖分 LCT Top Tree LCT时间复杂度 线段树每次查询是严格\(\log n\)的,然而splay维护连续段的时候,如果每次查 ...
- 2019暑期金华集训 Day5 生成函数
自闭集训 Day5 生成函数 一般生成函数 无脑地把序列变成多项式: \[ \{a_i\}\rightarrow A(x)=\sum_{n} a_nx^n \] 形式幂级数 生成函数是一种形式幂级数. ...
- 2019暑期金华集训 Day2 线性代数
自闭集训 Day2 线性代数 高斯消元 做实数时,需要找绝对值最大的作为主元,以获取更高精度. 在欧几里得环(简单例子是模合数)意义下也是对的.比如模合数意义下可以使用辗转相除法消元. 欧几里得环:对 ...
- 2019暑期金华集训 Day1 组合计数
自闭集训 Day1 组合计数 T1 \(n\le 10\):直接暴力枚举. \(n\le 32\):meet in the middle,如果左边选了\(x\),右边选了\(y\)(且\(x+y\le ...
随机推荐
- 在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据)
原文:在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决 ...
- SQL Server2008 删除重复记录只剩一条(无Uid)
INSERT INTO 表1 SELECT * FROM 视图1 CREATE TABLE ##TMP01 ---创建 ...
- WSL 服务自动启动
WSL 服务自动启动 参考 https://zhuanlan.zhihu.com/p/47733615 Windows 启用 WSL 功能支持 > Enable-WindowsOptionalF ...
- selenium2自动化测试实战--基于Python语言
自动化测试基础 一. 软件测试分类 1.1 根据项目流程阶段划分软件测试 1.1.1 单元测试 单元测试(或模块测试)是对程序中的单个子程序或具有独立功能的代码段进行测试的过程. 1.1.2 集成测试 ...
- vue实现组件切换的两种方式
<!DOCTYPE html> <html> <head> <title>组件的切换</title> <meta charset=&q ...
- KeepAlive细谈
来自: http://blog.sina.com.cn/s/blog_e59371cc0102ux5w.html 最近工作中遇到一个问题,想把它记录下来,场景是这样的: 从上图可以看出,用户通过Cli ...
- prometheus监控(小试牛刀)
prometheus监控(小试牛刀) 环境:全部服务都是基于docker运行 本文略微草率,好文章在这里,特别好如下: https://www.cnblogs.com/tchua/p/11120228 ...
- Android面试题 请解释下单线程模型中Message、Handler、MessageQueue、Looper之间的关系
简单的说,Handler获取当前线程中的looper对象,looper用来存放从MessageQueue中取出的Message,再由Handler进行Message分发和处理,按照先进先出执行. Me ...
- 如何11 周打造全能Python工程师!
在这个大数据和人工智能的时代,不管你是编程初学者,还是想学习一门其他语言充实自己,Python都是最好的选择之一. 它简洁.优雅.易学,被越来越多的大学作为计算机新生的入门语言: 它是大数据和人工智能 ...
- nginx编译安装和功能介绍
nginx介绍 nginx: engine X,是由1994年毕业于俄罗斯国立莫斯科鲍曼科技大学的同学为俄罗斯rambler.ru公司开发的,开发工作最早从2002年开始,第一次公开发布时间是2004 ...