[心得]暑假DAY1 | 7-7考试总结
呼。。
正式开始暑假集训。
今天一上午还在搞7-7的考试改题
然而,该来该去,TLE48过不去了
不知道哪的问题,loj上1w3ms(卡常都没能救得了)
至于T1和T3,简单总结一下算了
排序
感觉很像分治的样子
因为要想得到最终的顺序序列,它的子序列一定要是顺序
具体的,进行dfs,搜索每一次的操作
我们只有在小区间合法的情况下在交换大区间
最后得到一个合法的操作方案
如果确定了操作的个数和位置,操作顺序改变,又能产生新序列
所以每次dfs找到新的操作个数,得到的贡献是out的阶乘
统计答案即可
放棋子
很重要的是
一些确定的棋子所在的行列位置不影响转移
那么用g[i][j][k]表示k枚相同的棋子占任意i行,j列的方案数
g转移:g[i][j][k]=C(i*j,k0)-sigma(g[l][r][k])*C(i,l)*C(j,r) l<=i,r<=j && !(l==i && r==j)
找到转移的补偿量很重要
那么今天开始了图论专项
菜肴制作
T1就栽了
一开始想直接拓扑最小字典序,很快发现显然不行
那么又想把 菜的每个限制都聚到一起,进行拓扑排序,也有问题
原来是倒序输出反向连边的拓扑最大序
因为小序号要尽量在前,就是说,先一心把小的输出了,再考虑大序号
比如样例
5 2
4 3
制作1之后,虽然当前可制作的4比5小,但我们要先考虑做2,也就是把5做了,再2,4,3
可以发现大的序号选或不选 取决与 它限制的小序号
那么这其实是“小的限制大的”了
于是反向建边
这样得到的拓扑序用倒序输出的话可以满足原来的限制
那么在反图中我们先做大序号,倒序输出即可成为 小序号尽可能先做
矩阵游戏
一道二分图。。
其实二分图挺迷的,有时候特别难想,但有时候也挺套路的
我们发现初始在一行/一列的黑白快在交换过程中始终在同一行/列
考虑最终,对角线格子成黑色
也就是说,每一行都对应一个专属的黑快
(这样无论怎么交换,最后都是一行专属一个)
把行/列分别为二分图的左右部分
二分图能完全匹配,就有解
约会
因为N个点N条边,所以每个图里一定有且仅有一个环
把这个环缩成点就变成一棵树,并且树根就是这个环
在树上找lca,顺便计算深度
那么对于每次询问,如果它们的lca不是树根,那么分别输出各自距离lca的距离
如果lca是树根,还要在环内操作
取环内某个点为起点,顺着路线依次排距离
我们把原始图中的点用并差集指向环中的点
那么最后就是各自距离lca的距离加上在环内走的距离
一定是一个人走,一个人停在原地等才是最优情况
比较环内两种情况:a走b等,b走a等,按题意特判即可
[心得]暑假DAY1 | 7-7考试总结的更多相关文章
- [心得]暑假Day 8
em. 一波爆炸后回到了一个原始位置rank33 最近两场考试没啥状态 总感觉都读不懂题目了 T1 因为有的边要经过两次,不妨把边复制成双倍,那么再去掉2条,如果能一遍把剩下的边过完,也就是成为一笔画 ...
- [心得]暑假DAY 5
好久没更新博客了 最近事情太多太多 tarjan进阶,点双边双 T2压力 最大坑点:点双缩点 它不是直接把割点连成树(割点会有环) 而是用割点作”中介“,联接点双构成一颗树(所谓圆方树) 接着在上面进 ...
- 正睿 2019 省选附加赛 Day1 T1 考考试
比较奇怪的一个枚举题. 注意到10=2*5,所以10^k的二进制表示一定恰好在末尾有k个0. 考虑从小到大去填这个十进制数. 填的时候记录一下当前的二进制表示. 每次尝试去填0或者10^k. 如果要填 ...
- noip2014 考试总结
noip:最初估分580,明间数据:570,初测估分:510-570,最终得分:570 这次noip怎么说呢,发挥的还是比较理想吧,不过还是犯了一些“低级错误”,虽然没有造成十分严重的后果,但是还是不 ...
- 2019年11月18日 JAVA期中考试 增删改查
一.题目 石家庄铁道大学 青年志愿者服务网(20分) 1.项目需求: 为了适应社会主义市场经济发展的需要,推动青年志愿服务体系和多层次社会保障体系的建立和完善,促进青年健康成长,石家庄铁道大学急需 ...
- 20150127 学军集训 day1
day1 就直接考试... 和说好的不一样啊 第一题看都没怎么看就pass了,构造的题我一向没什么把握.然后瞟到第三题有30分可做,虽然要写的代码很大...反正我是写习惯了..期间纠结了一会还写了一个 ...
- 记我一年的OI之路
upd:感觉没必要设密码了吧,把这个发出来还能显得自己弱颓一些.. 自从我刚刚接触c++,到现在已经快一年了吧,这一年中,我学到了很多,失去了很多,也得到了很多. 开通了blog,那就从现在,就是一个 ...
- CTSC2016&&APIO2016滚粗记&&酱油记&&游记<del>(持续更新)</del>
挖一波坑 #include <cstdio> using namespace std; int main(){ puts("转载请注明出处:http://www.cnblogs. ...
- $PkuWc\ 2018$ 酱油记
PkuWc 2018 酱油记 1. Day -INF 又停了一个月课...... 感觉这个月的收获还是蛮大的,刚来的时候还只会线段树,到现在LCT都学了... 这个月不停在考试,自己考试技巧也提升了不 ...
随机推荐
- whistle学习(二)之启动、停止、重启、更新whistle等命令
新版本的whistle支持三种等价命令whistle,w2,wproxy 启动whistle w2 start 启动时指定端口 w2 start -p (// 不设置端口默认使用8899) 默认端口为 ...
- linux环境下,springboot jar启动方式
linux环境下,springboot jar启动方式 一.前台启动(ctrl+c会关掉进程) java -jar application.jar 二.后台启动(ctrl+c不会关闭) java -j ...
- Wxpython pannel切换
演示效果 实现panel切换思路 1.创建所有在某个区域需要切换面板对象,设置为None self.panel_Celan1 = None self.panel_Celan2 = None self. ...
- 2.vi 和 vim 编辑器
Linux系统的命令行下的文本编辑器 三种模式 一般模式:打开文档的默认模式 编辑模式 可以进行编辑,要按下 i a o r 等字母后才能从一般模式进入编辑模式 按下ESC 退出编辑模式 命令 ...
- sql 存储过程笔记
create procedure SP_Wim_GetWorkSubSectionById(@paramId as int)asbegindeclare @id as int;declare @lvI ...
- ubuntu版本信息查看
1.cat /etc/issue 2.cat /etc/lsb-release 3.uname -a 4.cat /proc/version 5.lsb_release -a 显卡信息1.lspci ...
- Linux系统初始化脚本
#查看centos的版本号 CentOS_version=`cut -d /etc/centos-release | cut -d` #改变PS3格式 PS3="Please enter t ...
- functools:管理函数的工具
介绍 functools模块提供了一些工具来管理或扩展和其他callable对象,从而不必完全重写 修饰符 偏函数partial from functools import partial ''' f ...
- SQL语句复习【专题六】
SQL语句复习[专题六] 用户 + 创建表 --创建一个新的用户,然后给新的用户创建一张表,然后给表中添加一些数据.查询表中的数据 --创建用户需要比较大的权限 DBA create user di ...
- K8S搭建过程随笔_证书CFSSL
安装CFSSL mkdir -p /opt/k8s/cert && cd /opt/k8swget https://pkg.cfssl.org/R1.2/cfssl_linux-amd ...