2020.12.12【NOIP提高B组】模拟 总结
第一次来 B 组做,虚的很
T1: 容斥原理
比赛时也打了个大致,但挂了,只有 50 分。
赛后重构了一下代码,AC
\(UPDATE:2020/12/13\ \ \ 14:10\)
思路:
像前缀和一样,先求出 [1,r] 的个数,在求出 [1,l-1] 的个数,最后相减
求法就是典型的容斥原理,用深搜来看第 i 个选不选,复杂度为\(O(2^n)\)
传参时多传一个最小公倍数,注意容斥时的奇负偶正
T2: 玄学
正解应该是 Treap ,但不会
不过 WTF?暴力能对?
但是考试时看了看样例输入,于是多打了一个换行。。。
\(UPDATE:2020/12/14\ \ \ \ 20:10:00\)
打出了多余的正解:
壳用一个双向队列 deque ,剩下的用一个 stack ,翻转用一个 tag 标记,操作 3 直接 tag^=1
事实证明 STL 常数真的大,跑得比暴力还慢。
T3:规律
\(m\le 11\)据说每一种情况都有一种规律
本蒟蒻只会\(m=1\)时奇偶性和\(m=2\)时高精度+斐波那契数列
\(UPDATE:2020/12/13\ \ \ 14:10\)
打消上面的疑虑,这题其实是道分段题
1:m>5
可以看出这就是 50% 的数据,因为 n 较小,可以直接状压 DP
设 F[i][s] 为前 i 行都放满,第 i 行状态为 s 的方案数(0是被填了,1是没有)
可以枚举行数 i 和 i-1 行的状态 j ,再用 Dfs 求出合法状态。
若 S 是第 i 行状态,T 是第 i-1 行状态,可得 \(F[i][S]=\sum F[i-1][T]\)
Dfs(第几行 i,状态的第几位 j,S,T)
- 看看有没有完成 S 状态,若完成则更新 F[i][S] 并返回
- 若 T 第 j 位是 0 ,Dfs(i,j+1,S 第 j 位为 1,T)
- 否则 Dfs(i,j+1,S,T)
- 若 T 第 j 位是 0 且 T 第 j+1 位是 0 且不越界, Dfs(i,j+2,S,T)
最后输出 F[n][0] ,初始化 F 除 F[0][0]=1 其他都是 0
2:m<=5
由于 \(n\le 10^{200}\) 所以可以想到数学方法,而直接肯定会炸,想到矩阵快速幂优化递推
可以用类似上一种情况的方法,把一对合法状态 S 和 T 再矩阵 tmp 中 tmp[S][T] 赋为 1
然后用矩阵快速幂求出 \(ans=tmp^n\) 其实就是一个简单的高精除以低精和\(2^m\times2^m\)的矩阵乘法
最后输出 ans[0][0]
T4:DP
奆佬们都说事二分+单调队列优化DP
于是本蒟蒻想到了 N 个月前没做出来的题“跳房子”,选择暂时放弃
\(UPDATE:2020/12/13\ \ \ 14:10\)
思路:
先二分答案为 mid ,考虑写 check 函数
设 F[i] 为在符合条件的情况下做了前 i 题的最少时间
显然 \(F_i = \min(F_j)+a[i]\ \ \ (j\in [i-mid+1,i-1])\)
最后判断是否有\(F_i<=t\ \ \ (i\in [n-mid+1,n])\)
由于暴力求区间最小会超时,可以用常数较小的单调队列维护,总复杂度\(O(nlogn)\)
总结
这次考试成绩并不理想,虽然只是第一次,却失误比较多
希望以后能看清题目,不打挂会的题目
2020.12.12【NOIP提高B组】模拟 总结的更多相关文章
- 5820. 【NOIP提高A组模拟2018.8.16】 非法输入(模拟,字符串)
5820. [NOIP提高A组模拟2018.8.16] 非法输入 (File IO): input:aplusb.in output:aplusb.out Time Limits: 1000 ms ...
- JZOJ 5818. 【NOIP提高A组模拟2018.8.15】 做运动
5818. [NOIP提高A组模拟2018.8.15] 做运动 (File IO): input:running.in output:running.out Time Limits: 2000 ms ...
- JZOJ 5812. 【NOIP提高A组模拟2018.8.14】 区间
5812. [NOIP提高A组模拟2018.8.14] 区间 (File IO): input:range.in output:range.out Time Limits: 1000 ms Memo ...
- 2021.06.12【NOIP提高B组】模拟 总结
T1 题目大意:有 \(n\) 个点,到点 \(i\) 可以获得 \(A_i\) ,同时消耗 \(B_i\) 若当前价值小于 \(B_i\) 则不能到,问从 \(P\) 开始,任一点结束后的最大值. ...
- [JZOJ5817] 【NOIP提高A组模拟2018.8.15】 抄代码
Description J 君是机房的红太阳,每次模拟她总是 AK 虐场.然而在 NOIP2117 中,居然出现了另一位 AK 的选手 C 君! 这引起了组委会的怀疑,组委会认为 C 君有抄袭 J 君 ...
- JZOJ5822 【NOIP提高A组模拟2018.8.16】 量子纠缠
这是一道很巧妙的题目. 今早,我调了好久,终于将它切掉了-- 题目 Description Input 第一行包含一个正整数 m,代表操作数. 接下来 m 行,每行可能有以下形式: 1 s 代表将数字 ...
- [JZOJ5818] 【NOIP提高A组模拟2018.8.15】 做运动
Description 一天,Y 君在测量体重的时候惊讶的发现,由于常年坐在电脑前认真学习,她的体重有了突 飞猛进的增长. 幸好 Y 君现在退役了,她有大量的时间来做运动,她决定每天从教学楼跑到食堂来 ...
- 【NOIP提高A组模拟2018.8.14】 区间
区间加:差分数组修改 O(n)扫描,负数位置单调不减 #include<iostream> #include<cstring> #include<cstdio> # ...
- [jzoj 5782]【NOIP提高A组模拟2018.8.8】 城市猎人 (并查集按秩合并+复杂度分析)
传送门 Description 有n个城市,标号为1到n,修建道路花费m天,第i天时,若gcd(a,b)=m-i+1,则标号为a的城市和标号为b的城市会建好一条直接相连的道路,有多次询问,每次询问某两 ...
随机推荐
- EMS修改邮箱容量限制的方法
使用PowerShell命令完成邮箱数据库限制任务. 以Exchange管理员身份打开EMS控制台.在PowerShell命令提示符下,键入如下命令. Set-MailboxDatabase Test ...
- JavaSE常用类之File类
File类 只用于表示文件或目录的信息,不能对文件内容进行访问. java.io.File类∶代表文件和目录.在开发中,读取文件.生成文件.删除文件.修改文件的属性时经常会用到本类. File类不能访 ...
- SpringMVC-获得Restful风格的参数
使用@PathVariable注解:接收请求路径中占位符的值 @RequestMapping("/report18/{username}") @ResponseBody publi ...
- 数据库纳管平台DBhouse的技术路线与实践
为帮助开发者更好地了解和学习前沿数据库技术,腾讯云数据库特推出"DB · TALK"系列技术分享会,聚焦干货赋能创新,邀请数十位鹅厂资深数据库专家每月和您一起深入探讨云数据库的内核 ...
- grpc流模式-go实现
目录 1. 什么是数据流 2. grpc的四种数据流 2.1 简单模式 2.2 服务端数据流模式 2.3 客户端数据流模式 2.4 双向数据流 3. 上代码 3.1 代码目录 3.2 编写stream ...
- el-transfer增加拖拽功能
el-transfer增加拖拽排序,左右互相拖拽功能: npm i sortablejs <template> <el-transfer ref="transfer&quo ...
- @Resource与构造函数踩坑
(虽然解决了需求,但我还是没搞懂为什么构造函数结束后,调用userMapper注入还是为空!) 首先,我有一个没有问题的userMapper类,用于处理user的数据库处理. 其次,我在另一个类里面使 ...
- 【面试普通人VS高手系列】死锁的发生原因和怎么避免
一个去阿里面试的小伙伴私信我说:今天被一个死锁的问题难到了. 平常我都特意看了死锁这块的内容,但是回答的时候就想不起来. 这里可能存在一个误区,认为技术是要靠记的. 大家可以想想,平时写代码的时候,这 ...
- XCTF练习题---MISC---reverseMe
XCTF练习题---MISC---reverseMe flag:flag{4f7548f93c7bef1dc6a0542cf04e796e} 解题步骤: 1.观察题目,下载附件 2.拿到手以后发现是个 ...
- 【ACM程序设计】差分
差分 假设有一个数列,我们需要对数列中的一个区间加上或减去一个值,直接想到的便是对该区间进行一次循环逐项加减. 但是当请求的操作变得非常多的时候,每次请求都进行一次循环会很容易爆时间,因此我们引入了差 ...