TJOI出一堆模板题还玩一堆梗是什么鬼

甲苯先生的字符串(矩阵快速幂)

矩阵快速幂模板题

代码

甲苯先生的滚榜(树状数组、线段树)

最开始想平衡树搞,但是平衡树太难写了

一次答案的查询相当于查询比当前的人AC数多的人数+和当前的人AC数一样多,但是罚时更少的人。前者可以使用树状数组维护每一种AC数量的人数的前缀和,后者使用动态开点线段树,在修改的时候可以一并求出答案。

注意动态开点线段树及时回收无用空间,空间消耗就很少了。

如果不知道怎么开数组就统统开\(5 \times 10^6\)……

代码

唱、跳、rap 和篮球(容斥、生成函数)

律师函警告

其实这道题也挺板子的,但是容斥没学好有点不会qwq

注意到两个不合法序列之间不可能相交,所以可以容斥序列中总共出现了多少个不合法序列,然后计算本质不同的排列的方案数。由指数型生成函数,有\(i\)个不合法序列的序列的贡献是\(n![x^n]\frac{x^{4i}}{i!}(\sum\limits_{j=0}^{a-i} \frac{x^j}{j!})(\sum\limits_{j=0}^{b-i} \frac{x^j}{j!})(\sum\limits_{j=0}^{c-i} \frac{x^j}{j!})(\sum\limits_{j=0}^{d-i} \frac{x^j}{j!})\)。

直接NTT复杂度\(O(n^2logn)\)可以通过,但有复杂度更优的做法:枚举\(i\)时维护\((\sum\limits_{j=0}^{a-i} \frac{x^j}{j!})(\sum\limits_{j=0}^{b-i} \frac{x^j}{j!})\)和\((\sum\limits_{j=0}^{c-i} \frac{x^j}{j!})(\sum\limits_{j=0}^{d-i} \frac{x^j}{j!})\),因为\(i\)每次增大\(1\),这四个式子只会少一项,所以可以\(O(n)\)更新,求出这两个多项式的卷积的其中一项也可以\(O(n)\)。这样复杂度变为\(O(n^2)\)。

代码

大中锋的游乐场(最短路)

分层图最短路模板题

代码

甲苯先生和大中锋的字符串(SAM)

SAM求endpos模板题

代码

甲苯先生的线段树(记忆化搜索)

谢罪警告、328警告

原题:CF750G 禁赛3年警告

应该是TJOI里面最妙的题目了。第一问暴力跳父亲。在下面的叙述中,设第一问的答案为\(len\)。

对于第二问,考虑枚举链上深度最低的点\(x\)、\(x\)的左儿子和右儿子的链深度\(L,R\)(\(L,R\)可以为\(0\)),记作三元组\((x,L,R)\),那么这条链的编号总和的下界是\(x+2x+...+2^Lx+(2x+1)+(4x+2)+...+(2^Rx+2^{R-1}) = (2^{L+1}+2^{R+1}-3)x+2^R-1\),也就是两条链都向左延伸的情况。

对于长度为\(L\)的左链,自底向上,第\(1,2,...,L-1\)个点都可以选择其父亲的左儿子或者右儿子,对于第\(i\)个点,选择右儿子相比选择左儿子编号之和会增加\(\sum\limits_{j=0}^{i-1} 2^j = 2^i-1\),右链同理。那么不难得到整条链的编号和上界是\((2^{L+1}+2^{R+1}-3)x+2^R-1+2^L+2^R-L-R-2\),即两条链都向右延伸。因为\(2^L+2^R-L-R-2 < 2^{L+1}+2^{R+1}-3\),所以\((x,L,R)\)的链编号和上界比\((x+1,L,R)\)的下界还要小,说明每一个\(x\)对应的链编号和范围无交。

那么不难得到枚举了\(L,R\)之后,\(x\)只有可能等于\(\lfloor \frac{len - 2^R+1}{2^{L+1}+2^{R+1}-3} \rfloor\)。接下来我们的任务是给左链和右链的节点分配是其父亲的左儿子还是右儿子。上面提到了第\(i\)个点选择右儿子相比选择左儿子会有\(2^i-1\)的增加量,所以我们需要求出一个长度为\(L-1\)的\(01\)串和长度为\(R-1\)的\(01\)串,\(01\)串的第\(i\)位为\(1\)有\(2^i-1\)的贡献,要求两个串的贡献和等于\(len - ((2^{L+1}+2^{R+1}-3)x+2^R-1)\)。这个可以数位DP,如果懒可以大力记忆化搜索。

至于记搜复杂度反正比数位DP的\(O(d^5)\)快很多就完事了证是不可能会证的

代码

TJOI2019的更多相关文章

  1. [TJOI2019]唱、跳、rap和篮球_生成函数_容斥原理_ntt

    [TJOI2019]唱.跳.rap和篮球 这么多人过没人写题解啊 那我就随便说说了嗷 这题第一步挺套路的,就是题目要求不能存在balabala的时候考虑正难则反,要求必须存在的方案数然后用总数减,往往 ...

  2. [TJOI2019]甲苯先生和大中锋的字符串——后缀自动机+差分

    题目链接: [TJOI2019]甲苯先生和大中锋的字符串 对原串建后缀自动机并维护$parent$树上每个点的子树大小,显然子树大小为$k$的节点所代表的子串出现过$k$次,那么我们需要将$[len[ ...

  3. [TJOI2019]大中锋的游乐场——最短路+DP

    题目链接: [TJOI2019]大中锋的游乐场 题目本质要求的还是最短路,但因为有第二维权值(汽水看成$+1$,汉堡看成$-1$)的限制,我们在最短路的基础上加上一维$f[i][j]$表示到达$i$节 ...

  4. [TJOI2019]甲苯先生的滚榜——非旋转treap

    题目链接: [TJOI2019]甲苯先生的滚榜 要求维护一个二维权值的集合并支持单点修改,用平衡树维护即可. 因为$n\le 10^6$但$m\le 10^5$,所以最多只有$10^5$个人被操作. ...

  5. [TJOI2019]甲苯先生的字符串——矩阵乘法+递推

    题目链接: [TJOI2019]甲苯先生的字符串 我们用一个$26*26$的$01$矩阵记录任意两个字符是否能相邻. 设$f[i][j]$表示处理完前$i$个字符,第$i$个字符为$j$的方案数. 可 ...

  6. [TJOI2019]唱、跳、rap和篮球——NTT+生成函数+容斥

    题目链接: [TJOI2019]唱.跳.rap和篮球 直接求不好求,我们考虑容斥,求出至少有$i$个聚集区间的方案数$ans_{i}$,那么最终答案就是$\sum\limits_{i=0}^{n}(- ...

  7. 【LOJ】#3109. 「TJOI2019」甲苯先生的线段树

    LOJ#3109. 「TJOI2019」甲苯先生的线段树 发现如果枚举路径两边的长度的话,如果根节点的值是$x$,左边走了$l$,右边走了$r$ 肯定答案会是$(2^{l + 1} + 2^{r + ...

  8. [luogu5339] [TJOI2019]唱、跳、rap和篮球(容斥原理+组合数学)(不用NTT)

    [luogu5339] [TJOI2019]唱.跳.rap和篮球(容斥原理+组合数学)(不用NTT) 题面 略 分析 首先考虑容斥,求出有i堆人讨论的方案. 可以用捆绑法,把每堆4个人捆绑成一组,其他 ...

  9. 洛谷P5341 [TJOI2019]甲苯先生和大中锋的字符串

    原题链接P5341 [TJOI2019]甲苯先生和大中锋的字符串 题目描述 大中锋有一个长度为 n 的字符串,他只知道其中的一个子串是祖上传下来的宝藏的密码.但是由于字符串很长,大中锋很难将这些子串一 ...

  10. 洛谷P5338 [TJOI2019]甲苯先生的滚榜

    原题链接洛谷P5338 [TJOI2019]甲苯先生的滚榜 题目描述 甲苯先生在制作一个online judge,他发现做比赛的人们很关心自己的排名(显而易见),在acm赛制的比赛中,如果通过题目数量 ...

随机推荐

  1. tengine负载均衡高可用配置

    环境 Tengine-master:192.168.109.100 Tengine-slave:192.168.109.101 tomcat01:192.168.109.102 tomcat02:19 ...

  2. OpenFOAM——平行平板间具有相对运动(库埃特流)

    本算例翻译整理自:http://the-foam-house5.webnode.es/products/chapter-1-plane-parallel-plates-case/ 这个算例研究了一个距 ...

  3. CFD-Post批量添加截面

    有时候我们需要在一个算例中截取多个面 我们打开CFD-Post 我们编写如下的Python代码来实现在一个算例当中截取多个面 源代码如下: 上述代码完成以后,我们重新打开CFD-Post

  4. ICEM-哑铃(无厚度)

    原视频下载地址:https://pan.baidu.com/s/1i44hdkh 密码: 96dh

  5. Cloudera-Manager(一) —— 基本概念及使用

    概念 Cloudera Manager(简称CM)是Cloudera公司开发的一款大数据集群安装部署利器,这款利器具有集群自动化安装.中心化管理.集群监控.报警等功能,极大的提高集群管理的效率. AP ...

  6. 刷题记录:[0CTF 2016]piapiapia

    目录 刷题记录:[0CTF 2016]piapiapia 一.涉及知识点 1.数组绕过正则及相关 2.改变序列化字符串长度导致反序列化漏洞 二.解题方法 刷题记录:[0CTF 2016]piapiap ...

  7. vue+elementui搭建后台管理界面(6登录和菜单权限控制[二])

    根据权限计算路由的代码 /** * 通过meta.role判断是否与当前用户权限匹配 * @param roles * @param route */ function hasRoles (roles ...

  8. 杀死Linux中的defunct进程(僵尸进程)的方法指南

    杀死Linux中的defunct进程(僵尸进程)的方法指南_LINUX_操作系统_脚本之家https://www.jb51.net/LINUXjishu/457748.html 这样能看到僵尸进程.

  9. Leetcode: Split BST

    Given a Binary Search Tree (BST) with root node root, and a target value V, split the tree into two ...

  10. 360极速浏览器安装vue-devtools插件

    360极速浏览器扩展程序中心并没有提供vue-devtools插件,因此需要自己安装.本文介绍方法适用于所有Chrome内核浏览器. 本人已将编译后的Chrome插件包上传网盘,需要的可以直接下载使用 ...