Solution -「CF 1237E」Balanced Binary Search Trees
\(\mathcal{Description}\)
Link.
定义棵点权为 \(1\sim n\) 的二叉搜索树 \(T\) 是 好树,当且仅当:
除去最深的所有叶子后,\(T\) 是满的;
对于 \(T\) 中任意结点 \(r\),若 \(r\) 存在左儿子 \(u\),则 \(r\not\equiv u\pmod2\);
若 \(r\) 存在右儿子 \(v\),则 \(r\equiv v\pmod2\);
给定 \(n\),求 好树 数量。答案对 \(998244353\) 取模。
\(\require{cancel} \cancel{n\le10^6}~n\le10^{10^6}\)。
\(\mathcal{Solution}\)
分析一下含有 \(n\) 个结点的 好树 的性质:
好树 的子树是 好树。
树根 \(r\) 有 \(r\equiv n\pmod2\)。因为从根一直走右儿子奇偶性不变。
当 \(n>1\),好树 不满。若满,最大值和次大值必为右儿子-父亲关系,不满足定义。
由 3.,当 \(n>2\),好树 树根的左右子树的最大满层相同。
我们这样断言:最大满层深度为 \(h\) 的 好树 存在且仅存在两个,且它们的大小之差为 \(1\)。
给出证明。设含 \(n\) 个结点的 好树 有 \(f(n)\) 个,那么 \(f(1)=f(2)=1\),它们最大满层深度均为 \(1\)。归纳 \(n>2\) 的情形:
取一棵含 \(n\) 个点的 好树 \(T\),其树根为 \(r\),左右儿子为 \(u,v\),最大满层深度为 \(h\)。
由性质 1.,子树 \(u\) 和子树 \(v\) 是好树;
由性质 3.,子树 \(u\) 和子树 \(v\) 不满;
由假设,\(T\) 为好树,子树 \(u\) 和子树 \(v\) 最大满层相同。那么可以对这两棵子树进行归纳。
若 \(2\not\mid n\),
可知子树 \(u\),子树 \(v\) 大小奇偶性相同,由性质 4. 与归纳假设,子树 \(u\) 和子树 \(v\) 的大小相等,且均为偶数,继而有\[ f(n)=f^2\left(\frac{n-1}{2}\right)~~~~(n=4k+1,k\in\mathbb N^*).
\]若 \(2\mid n\),
可知子树 \(u\),子树 \(v\) 大小奇偶性不同,由归纳假设,子树 \(u\) 和子树 \(v\) 大小相差 \(1\),继而有\[ f(n)=f\left(\frac{n}{2}-1\right)f\left(\frac{n}{2}\right).
\](注意左右子树不能交换,所以只有一种放法。)
综上,不难发现 \(f(n)\) 在归纳条件下至多为 \(1\)。我们只需要证明存在某对使得 \(T\) 最大满层深度为 \(h\) 的 \(n_0\) 和 \(n_0+1\),使得 \(f(n_0)=f(n_0+1)=1\)。
构造,设当 \(h'=h-1\) 时已有 \(f(n_0')=f(n_0'+1)=1\),那么
若 \(2\mid n_0\),有 \(f(2n_0)=f(2n_0+1)=1\);
若 \(2\not\mid n_0\),有 \(f(2n_0+2)=f(2n_0+1)=1\)。
综上,归纳可行,原命题成立。 \(\square\)
利用最后一步的构造方法,我们可以 \(\mathcal O(\log n)\) 地求得所有 \(n_0\le n,f(n_0)=1\) 的 \(n_0\)。当然也能以同样复杂度判断 \(f(n)\) 是否为 \(1\)。
正确解题姿势:写 \(\mathcal O(n^2)\) DP,打表秒出规律。
\(\mathcal{Code}\)
Subtask12 即打表代码。
/*~Rainybunny~*/
#include <bits/stdc++.h>
#define rep( i, l, r ) for ( int i = l, rep##i = r; i <= rep##i; ++i )
#define per( i, r, l ) for ( int i = r, per##i = l; i >= per##i; --i )
const int MAXN = 5e6;
int n, M;
bool ans[MAXN + 5];
inline int imin( const int u, const int v ) { return u < v ? u : v; }
inline int imax( const int u, const int v ) { return u < v ? v : u; }
inline int mul( const int u, const int v ) { return 1ll * u * v % M; }
inline void addeq( int& u, const int v ) { ( u += v ) >= M && ( u -= M ); }
namespace Subtask12 {
int bitw[MAXN + 5], f[MAXN + 5];
inline void main() {
f[0] = f[1] = 1, bitw[0] = -1;
rep ( i, 2, n ) {
bitw[i] = bitw[i >> 1] + 1;
rep ( j, 1, i ) {
if ( ( i & 1 ) == ( j & 1 )
&& imin( bitw[j], bitw[i - j + 1] ) + 1 >= bitw[i]
&& imax( bitw[j - 1], bitw[i - j] ) + 1 == bitw[i] ) {
// printf( "(%d,%d)->%d\n", j - 1, i - j, i );
addeq( f[i], mul( f[j - 1], f[i - j] ) );
}
}
if ( f[i] ) assert( f[i] == 1 ), printf( "%d\n", i );
}
}
} // namespace Subtask12.
int main() {
freopen( "tree.in", "r", stdin );
freopen( "tree.out", "w", stdout );
scanf( "%d %d", &n, &M );
for ( int i = 2, op = 1; i <= MAXN + 1; ) {
ans[i] = ans[i - 1] = true;
i = i << 1 | op, op ^= 1;
}
putchar( ans[n] ^ '0' ), putchar( '\n' );
return 0;
}
Solution -「CF 1237E」Balanced Binary Search Trees的更多相关文章
- Codeforces 1237E Perfect Balanced Binary Search Tree
题目链接 Observations 含有 $n$ 个点且 key(以下也称 key 为「权值」)是 1 到 $n$ 的 BST 具有下列性质: 若 $k$ 是一个非根叶子且是个左儿子,则 $k$ 的父 ...
- Solution -「CF 1342E」Placing Rooks
\(\mathcal{Description}\) Link. 在一个 \(n\times n\) 的国际象棋棋盘上摆 \(n\) 个车,求满足: 所有格子都可以被攻击到. 恰好存在 \(k\ ...
- Solution -「CF 1622F」Quadratic Set
\(\mathscr{Description}\) Link. 求 \(S\subseteq\{1,2,\dots,n\}\),使得 \(\prod_{i\in S}i\) 是完全平方数,并最 ...
- Solution -「CF 923F」Public Service
\(\mathscr{Description}\) Link. 给定两棵含 \(n\) 个结点的树 \(T_1=(V_1,E_1),T_2=(V_2,E_2)\),求一个双射 \(\varph ...
- Solution -「CF 923E」Perpetual Subtraction
\(\mathcal{Description}\) Link. 有一个整数 \(x\in[0,n]\),初始时以 \(p_i\) 的概率取值 \(i\).进行 \(m\) 轮变换,每次均匀随机 ...
- Solution -「CF 1586F」Defender of Childhood Dreams
\(\mathcal{Description}\) Link. 定义有向图 \(G=(V,E)\),\(|V|=n\),\(\lang u,v\rang \in E \Leftrightarr ...
- Solution -「CF 623E」Transforming Sequence
题目 题意简述 link. 有一个 \(n\) 个元素的集合,你需要进行 \(m\) 次操作.每次操作选择集合的一个非空子集,要求该集合不是已选集合的并的子集.求操作的方案数,对 \(10^9 ...
- Solution -「CF 1023F」Mobile Phone Network
\(\mathcal{Description}\) Link. 有一个 \(n\) 个结点的图,并给定 \(m_1\) 条无向带权黑边,\(m_2\) 条无向无权白边.你需要为每条白边指定边权 ...
- Solution -「CF 599E」Sandy and Nuts
\(\mathcal{Description}\) Link. 指定一棵大小为 \(n\),以 \(1\) 为根的有根树的 \(m\) 对邻接关系与 \(q\) 组 \(\text{LCA}\ ...
随机推荐
- CentOS7端口被占用的解决办法
1.根据端口号得到其占用的进程的详细信息 netstat -tlnp|grep 80tcp 0 0 192.168.33.10:80 0.0.0.0:* ...
- Leetcode算法系列(链表)之两数相加
Leetcode算法系列(链表)之两数相加 难度:中等给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字.如果,我们将 ...
- SSM实现支付宝支付
学习支付宝支付 一.支付宝测试环境代码测试 1.下载电脑网站的官方demo: 下载地址:https://docs.open.alipay.com/270/106291/ 2.下载解压导入eclipse ...
- 只需两步在Linux系统安装百度网盘--Ubuntu20
Linux Ubuntu系统安装百度网盘 百度网盘已支持Linux系统下载和使用.使用Linux系统下载并安装一个百度网盘是非常简单的,只需要以下两个步骤: 第一步 进入官网下载.deb类型的百度网盘 ...
- Docker的学习笔记(一)基础知识
概述 本人最近在学习docker相关的知识,既是工作本身的需要也是自己对技术的追求的必要,以后我也会推出容器相关的随笔,既可以增长自己的知识,也可以和读者广泛交流,岂不乐乎?话不多说.第一篇先介绍do ...
- 【Java】final
final final可以用来修饰的结构:类.方法.变量 final 用来修饰一个类:此类不能被其他类所继承. 比如:String类.System类.StringBuffer类 final 用来修饰方 ...
- 如何让 Hexo 在服务器稳定运行
声明 本文地址:如何让 Hexo 在服务器稳定运行 背景 博客系统终于又搭建起来了(好一个又),但是每隔一段时间去访问自己的网站总是访问不到,去服务器查询 ps aux | grep hexo,发现 ...
- VirtualBox 安装 Ubuntu 20.04 全流程
VirtualBox 安装 Ubuntu 20.04 全流程 内容概要 这个作业属于哪个课程 2022面向对象程序设计 这个作业要求在哪里 2022面向对象程序设计寒假作业1 这个作业的目标 在虚拟机 ...
- C# 获取DPI例子
public static float GetDpiX() { System.Windows.Forms.Panel p = new System.Windows.Forms.Panel(); Sys ...
- Cesium中级教程3 - Camera - 相机(摄像机)
Cesium中文网:http://cesiumcn.org/ | 国内快速访问:http://cesium.coinidea.com/ Camera CesiumJS中的Camera控制场景的视图.有 ...