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 ...
随机推荐
- Angular 学习笔记 (Angular 9 & ivy)
refer : https://blog.angularindepth.com/all-you-need-to-know-about-ivy-the-new-angular-engine-9cde47 ...
- java 线程并发(生产者、消费者模式)
线程并发协作(生产者/消费者模式) 多线程环境下,我们经常需要多个线程的并发和协作.这个时候,就需要了解一个重要的多线程并发协作模型“生产者/消费者模式”. Ø 什么是生产者? 生产者指的是负责生产数 ...
- javascript 之 Object.defineProperty
语法: Object.definePropty(obj,prop,descriptor); 参数: obj:要在其上定义属性的属性 prop:要定义或修改的属性的名称 desriptor:将被定义或修 ...
- 【转载】使用Response.WriteFile输出文件以及图片
Response对象是Asp.Net应用程序中非常重要的一个内置对象,其作用为负责将服务器执行好的信息输出给客户端,可以使用Response.WriteFile方法来像客户端输出文件或者图片,输出图片 ...
- ArduPilot存储管理 Storage EEPROM Flash
AP_HAL::Storage 此类可以应用于所有平台.PX4v1平台支持8k的EEPROM,Pixhawk平台支持16k的FRAM铁电存储器 存储大小定义:libraries/AP_HAL/AP_H ...
- javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certificatio
场景:Java调用PHP接口,代码部署在服务器上后,调用报错,显示PHP服务器那边证书我这边服务器不信任(我猜的). 异常信息: 2019-08-06 14:00:09,102 [http-nio-4 ...
- SQL SERVER-Job中Operators搬迁脚本
选中operators按F7,然后选中对象,生成脚本 USE [msdb] GO /****** Object: Operator [DB_ITDESK] Script Date: 5/30/2019 ...
- 【DRF框架】路由组件
视图组件涉及的路由补充: from rest_framework.viewsets import ViewSetMixin 对路由进行了重新的分发,重写了as_view() 方法,重新封装了请求方法 ...
- kali linux tools
1.HTTrack:网站复制机制 2.Google高级搜索命令 site:domain terms to search site :dsu.edu pat engebreston 3.kali lin ...
- Django drf: 跨域机制
一.同源策略 二.CORS(跨域资源共享)简介 三.CORS基本流程 四.CORS两种请求流程 五.Django项目中支持CORS 一.同源策略 同源策略是一种约定,它是浏览器最核心的最基本的安全功能 ...