NOI 模拟赛(I)

冲刺国赛5月2日第二场

t1 沉迷前缀和无法自拔,觉得扫描线是离散位置修改不好操作,没想到其实有零的情况只多了一点点
t2 在想回滚莫队,但是撤回操作不会很好地处理,并没有领会随机的意图……
t3 来者不善又是 FWT……


A. a

i 为右端点的最远左端点可以递推出来,虽然修改位置是离散的,但是只有 01 两个,用线段树可以很方便地维护出来(白学了半天线段树


B. b

把询问划分为多个区间完全包含的序列,可以发现个数为 n
对于每一个分别跑吉老师线段树即可


冲刺国赛5月4日第三场

考场上成功通过打表得到 t1 所有性质,写完还得自己造数据还被hzoj的阴间重测方式坑成零分
t2 想错没有发现矩形的合并关系
t3 拿上错误的 n2 和错误的特殊性质对拍拍过了……


B. 铃原露露

z<x<y 为例,对于固定的 zx 可以发现最小的 y 即可包含所有情形
而如果采用启发式合并,同时枚举 x,z 的复杂度是可以接受的
对于剩下的问题就是矩形加,求空白和
通用的方法是线段树维护历史版本最小值个数和,不过由于矩形的特殊的位置,可以用普通线段树+并查集直接维护


冲刺国赛5月9日第六场

t2 通过打表发现 n=2k+1ans=2Cat(k+1) 的特殊关系,通过修正原先推出的错误表达式懵出正确式子
t3 愣是一个小时每调对个 tarjan……


先来写一下题解的思路,首先形式化地刻画答案为 n 左括号数最大前缀和
枚举答案为 z,求出 z 的答案,每次左右括号的选择刻画为格点上的行走方向,转化为了格点计数问题


C. 防御工事

缩点虚树没得说,这个细节着实多……

  • 非割点军队当前点有一的贡献
  • 同一点双中贪心选择一个
  • 边并不能忽略,需要加入两个相邻割点(还是说理解错题解了

冲刺国赛5月10日第七场


B. 树上游走

image

考虑转移:
f[u][1]:对于子树父亲不能走,f[v][2]
sum=v!=uf[v][1]
f[u][0]

  • 进入子树后不返回,f[v][2]
  • 返回
    • 立即返回(儿子经过一次),1(dv+1)du(f[v][1]+sum)
    • 走过一条链(系数 1pv1dv+1
      • 只有一个儿子,au
      • 1du1sum

f[u][2]p 类似,只不过总情况为 du+1


C. 树的同构

首先枚举一条分隔边将树分成两个连通块并分别指定两个连通块中的根是哪个
f[i][j] 表示第一棵树的 i 和第二棵树的 j 匹配,子树内最多匹配多少个
可以发现子树内的信息相当于是以 f[u][v] 为边权的二分图最大权匹配


冲刺国赛5月24日第十四场

进行了一圈的看,发现只有 t1 可以进行一个题的做
于是进行一个表的打,有了关于 SG 函数的悟,于是进行一个代码的打,发现有了样例的过
t2 进行了一系列式子的推,发现有了样例的过,然而不能够进行暴力的打,于是获得了红红的 WA
t3 进行了一些复杂度的算,发现一点时间的卡,由于过于的懒,进行了暴力打之后进行了路的跑


B. 奇怪的拆分

首先最好把集合的合并关系看成二叉树计数
那么一种推法是斯特林数* 方案数
fi 表示有 i 个叶子的二叉树个数,可以得到递推式 fi=fi1(2i3),即新加入的两个节点可以放在每一个节点的旁边
另一种有扩展性的做法是直接去在划分二叉树的过程中考虑进标号的划分
fi=1+12(ik)fkfik
然后用指数生成函数求解


C. 奇怪的植物

正解是用矩乘来维护 AC 自动机上的 dp 转移,暴力一点是用倍增、树剖啥的总之都能过
一种优化掉倍增复杂度的做法是每个点只存 1low(depi) 的矩阵,查询的时候每次能跳 lowbit 就跳 lowbit,否则剩下的深度一定在 lowbit 范围内,这样随机下复杂度是 O(n) 的,为了手动随机,可以在根节点头上挂链

posted @   y_cx  阅读(123)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探
· 为什么 退出登录 或 修改密码 无法使 token 失效
点击右上角即可分享
微信分享提示