自闭集训 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 图论的更多相关文章

  1. 2019暑期金华集训 Day3 字符串

    自闭集训 Day3 字符串 SAM 考虑后缀树. SAM的parent树是反串的后缀树,所以后面加一个字符的时候相当于往串前面加一个字符,恰好多出了一个后缀. 于是可以以此来理解SAM. 每一条路径对 ...

  2. 2019暑期金华集训 Day7 分治

    自闭集训 Day7 分治 主定理 由于我沉迷调题,这个地方没听课. 某些不等式 咕了 nth_element 使用快速排序的思想,选一个中间点,看左右有多少个. 期望复杂度\(O(n)\). 首先把一 ...

  3. 2019暑期金华集训 Day7 动态规划

    自闭集训 Day7 动态规划 LOJ6395 首先发现这个树的形态没啥用,只需要保证度数之和是\(2n-2\)且度数大于0即可. 然后设\(dp_{i,j}\)表示前\(i\)个点用了\(j\)个度数 ...

  4. 2019暑期金华集训 Day6 杂题选讲

    自闭集训 Day6 杂题选讲 CF round 469 E 发现一个数不可能取两次,因为1,1不如1,2. 发现不可能选一个数的正负,因为1,-1不如1,-2. hihoCoder挑战赛29 D 设\ ...

  5. 2019暑期金华集训 Day6 计算几何

    自闭集训 Day6 计算几何 内积 内积不等式: \[ (A,B)^2\le (A,A)(B,B) \] 其中\((A,B)\)表示\(A\cdot B\). (好像是废话?) 叉积 \[ A\tim ...

  6. 2019暑期金华集训 Day5 树上数据结构

    自闭集训 Day5 树上数据结构 前置知识 点分治 边分治 树链剖分 LCT Top Tree LCT时间复杂度 线段树每次查询是严格\(\log n\)的,然而splay维护连续段的时候,如果每次查 ...

  7. 2019暑期金华集训 Day5 生成函数

    自闭集训 Day5 生成函数 一般生成函数 无脑地把序列变成多项式: \[ \{a_i\}\rightarrow A(x)=\sum_{n} a_nx^n \] 形式幂级数 生成函数是一种形式幂级数. ...

  8. 2019暑期金华集训 Day2 线性代数

    自闭集训 Day2 线性代数 高斯消元 做实数时,需要找绝对值最大的作为主元,以获取更高精度. 在欧几里得环(简单例子是模合数)意义下也是对的.比如模合数意义下可以使用辗转相除法消元. 欧几里得环:对 ...

  9. 2019暑期金华集训 Day1 组合计数

    自闭集训 Day1 组合计数 T1 \(n\le 10\):直接暴力枚举. \(n\le 32\):meet in the middle,如果左边选了\(x\),右边选了\(y\)(且\(x+y\le ...

随机推荐

  1. vue cli3 项目优化

    vue-cli3 Prefetch (官网内容) <link rel="prefetch"> 是一种 resource hint,用来告诉浏览器在页面加载完成后,利用空 ...

  2. 在论坛中出现的比较难的sql问题:10(删除多表中的同一个外键)

    原文:在论坛中出现的比较难的sql问题:10(删除多表中的同一个外键) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...

  3. iview的table组件中加入超链接组件,可编辑组件,选择组件,日期组件

    这篇文章主要介绍了iview的table组件中使用选择框,日期,可编辑表格,超链接等组件. 1.select选择组件 // tableColumn数组响应对象需要传入一个固定的option数组,如果该 ...

  4. Java中的反射机制和动态代理

    一.反射概述 反射机制指的是Java在运行时候有一种自观的能力,能够了解自身的情况为下一步做准备,其想表达的意思就是:在运行状态中,对于任意一个类,都能够获取到这个类的所有属性和方法:对于任意一个对象 ...

  5. element-ui 文件上传

    <el-form-item> <el-upload ref="upload" class="upload-demo" :action=&quo ...

  6. day14-python之集合函数字符串格式化

    1.集合 #!/usr/bin/env python # -*- coding:utf-8 -*- # s=set(['alex','alex','sb']) # print(s) # s=set(' ...

  7. REST,以及RESTful的讲解

    详见:https://blog.csdn.net/qq_21383435/article/details/80032375 1.传统下的API接口对比规则概念REST 系统的特征演化优点&缺点 ...

  8. Wireshark解密HTTPS数据流

    如果是chrome浏览器的数据流 直接配置”SSLKEYLOGFILE“就可以解密了. 实现过程: 1.配置系统环境变量 变量名:SSLKEYLOGFILE 变量值:随意指定一个存储路径,以便chro ...

  9. Linux 之 用户、用户组以及权限

    拥有者(user),拥有组(group),其他人(other) 由于Linux是一个多人多任务的系统,因此经常会出现同一台机器同时有多个人进行操作,为了考虑每个人的隐私权以及每个人喜好的工作环境,所以 ...

  10. rabbitMq实现延时队列

    原文:https://my.oschina.net/u/3266761/blog/1926588 rabbitMq是受欢迎的消息中间件之一,相比其他的消息中间件,具有高并发的特性(天生具备高并发高可用 ...