ZROI 19.08.09模拟赛
写在前面:为了保护正睿题目版权,这里不放题面,只写题解。
- A
\(70pts:\)
维护一个栈,从一侧向另一侧扫描,如果新加入的元素与当前栈顶相同,则出栈,否则进栈。显然一个子串是括号序列,当且仅当栈为空。
枚举起点,暴力模拟即可。复杂度\(O(n^2)\)。
\(100pts:\)
对于一个右端点,考虑哪些左端点可以和它匹配。
发现所有合法的左端点,两者栈的内容都是相等的,可以Hash判断。
实际上考虑每次加入字符时,只会在末尾变动一次,可以用trie树维护。复杂度\(O(\sigma n)\)。
- B
\(20pts:\)
随便爆搜即可。
\(40pts:\)
考虑状压,设\(f_{state}\)为选了\(state\)的建筑公司后,最大的花费。
每次转移时枚举最后选的建筑公司\(i\),现在需要求\(e_i\)。
直接算很难算,考虑容斥。
发现有一些点集,它们之间的边已经被之前的公司连过了。
枚举之前选的建筑公司的每个子集\(state'\),被它影响的点是与\(i\)的点集的交集,容斥系数是\((-1)^{|state'|}\)。
用bitset维护点集的交集,复杂度\(O(\frac{3^m n}{w})\)。
\(70pts:\)
发现本质不同的交集只有\(2^m\)个,预处理交集大小,容斥时可以直接算。复杂度\(O(\frac{2^m n}{w}+3^m)\)。
或者对于每个点,考虑它在哪些点集里出现了。对它未出现的点集的每个子集,将它的权值\(-1\),预处理复杂度可以降到\(3^m\)。
\(100pts:\)
高维前缀和:设有定义在集合上的函数\(f(S)\),现在要求\(g(T)=\sum_{S\subseteq T} f(S)\)。直接求是\(O(3^n)\)的,然而通过一些玄妙的手段,可以将它的复杂度降为\(O(2^n\cdot n)\)。
对预处理和容斥分别使用高维前缀和即可。
- C
\(100pts:\)
发现一个排列就是若干个环组成的置换,目标是把环的总数变为\(n\)。
考虑交换两个元素后环会如何变化。
发现如果交换同一个环的元素,环会被拆成两份。否则两个环会因此合并。
因此最小化操作次数等价于最小化合并环的次数。
考虑什么时候会合并环。对于一个环,如果内部有多于一种颜色(称作异色环),可以从每次交换颜色断点处的两个元素,形成一个新的自环。因此一个异色环可以直接拆成自环,不需要合并。
否则,环内任意两个元素都无法交换,则必须将其与包含其他颜色的环合并。
考虑至少需要合并多少次。发现一次合并最优可以将两个颜色不同的同色环合并成异色环。在所有同色环颜色相同时,则只能将一个同色环与某个异色环合并。
因此每次将出现次数最多的两种颜色的同色环合并是最优的,用堆维护即可。
一万个特判,一万个边界。辣鸡swk赛场上没调出来,成功爆零了。
这题太难写了所以放一下代码。戳这里qwq
对于消异色环,另外一种比较简单的写法是,钦点一种颜色,第一次消去这个颜色所有边,只留一条。第二次用这条边把整个环都消掉即可。
ZROI 19.08.09模拟赛的更多相关文章
- ZROI 19.08.07模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. "正睿从来没有保证,模拟赛的题目必须原创." "文案不是我写的,有问题找喵老师去."--蔡老师 ...
- ZROI 19.08.06模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. 今天正睿又倒闭了,从删库到跑路. 天祺鸽鸽txdy! A "不要像个小学生一样一分钟就上来问东西."--蔡老板 虽 ...
- ZROI 19.08.12模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. "我发现问题的根源是大家都不会前缀和."--敦爷 A 敦爷spj写错了,差点把蒟蒻swk送走 \(50pts:\) ...
- ZROI 19.08.11模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. dlstql,wsl A \(10pts:\) \(a=100,T=100\),对每个排列构造一个反的,一步到位即可. \(20pts ...
- ZROI 19.08.10模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. A \(20pts:\) 枚举操作序列然后暴力跑,复杂度\(O(6^n)\). \([50,80]pts:\) 枚举改成dfs,每层操 ...
- ZROI 19.08.05模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. A \(21pts:\) 随便枚举,随便爆搜就好了. \(65pts:\) 比较显然的dp,设\(f_{i,j,k}\)表示在子树\( ...
- ZROI 19.08.04模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. "这应该是正睿OI历史上第一次差评破百的比赛." "这说明来正睿集训的人越来越多了." &qu ...
- ZROI 19.08.08模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. 首先恭喜swk今天翻车! "小心大样例演你."--天祺鸽鸽 果然swk今天被大样例演死了,天祺鸽鸽诚不欺我! A ...
- ZROI 19.08.02 杂题选讲
给出\(n\)个数,用最少的\(2^k\)或\(-2^{k}\),使得能拼出所有数,输出方案.\(n,|a_i|\leq 10^5\). 显然一个绝对值最多选一次.这个性质非常强. 如果所有都是偶数, ...
随机推荐
- 转载-Mysql主主复制架构配置
Mysql主主复制架构配置 转载:原始出处 http://luoweiro.blog.51cto.com/2186161/658550MySQL主主复制结构区别于主从复制结构.在主主复制结构中,两台服 ...
- 阶段3 2.Spring_10.Spring中事务控制_7 spring基于注解的声明式事务控制
创建新项目 复制上一个pom.xml的内容.依赖和打包的方式 再复制src的代码过来 bean.xml.多导入context的声明 Service的实现类增加注解 dao的set方法删掉 通过Auto ...
- 阶段3 2.Spring_03.Spring的 IOC 和 DI_11 set方法注入
复制AccountServiceImpl类改名叫做AccountServiceImpl2 生成三个属性值的set方法.注入只需要set方法,并不需要get方法 配置bean,用到property这个标 ...
- 阶段3 2.Spring_03.Spring的 IOC 和 DI_6 spring中bean的细节之三种创建Bean对象的方式
目前这里能调用是因为,在service的实现类里面,new了一个dao的对象 正常情况下 这里不应该是new一个对象,应该等于null或为空 设置为空侯再运行就会报错 出错的原因是这里为null 需要 ...
- linux netstat 查看端口
1. netstat命令用于显示系统的网络信息,包括网络连接 .路由表 .接口状态2. 一般我们使用 netstat 来查看本机开启了哪些端口,查看有哪些客户端连接 [root@localhost ~ ...
- sql回显注入-笔记
拼接sql命令查询数据 注释 常用于sql注入 # 井号 单行注释 注意:URL编码 %23 -- 两个减号加空格 单行注释 /* ...
- spring boot-11.全局捕获异常
1.在Spring boot 中如果发生错误,浏览器访问会默认跳转到Whitelabel Error Page 这个错误页面,如果是客户端访问的话返回JSON格式的错误数据,说明spring boot ...
- 写 JSP 的痛点,真的非常痛!
一.前戏 前后端分离已成为互联网项目开发的业界标准使用方式,通过nginx+tomcat的方式(也可以中间加一个nodejs)有效的进行解耦,并且前后端分离会为以后的大型分布式架构.弹性计算架构.微服 ...
- laravel的monolog使用
Laravel 集成了 Monolog 日志函数库,Monolog 支持和提供多种强大的日志处理功能. 1.设置,日志模式 (1)Laravel 提供可立即使用的 single.daily.syslo ...
- 小白学习django第三站-自定义过滤器及标签
要使用自定义过滤器和标签,首先要设置好目录结构 现在项目目录下建立common的python包 再将common加入到setting.py中的INSTALLED_APP列表中 在common创建目录t ...