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}\ ...
随机推荐
- 怎样在 CentOS/RHEL 7/6 上安装和配置 Sendmail 服务器
在 CentOS 上,可以通过 mailx 命令 或 sendmail 命令来给因特网发送电子邮件. 关于前者的文章比较多,关于后者的文章比较少. 这里记录了我在 CentOS 7 上安装和配置 se ...
- linux修改配置文件关闭终端失效问题
当前shell环境为 交互式login-shell(非图形化界面环境) /etc/profile /etc/bash.bashrc ~/.profile ~/bashrc 当前环境为 交互式非logi ...
- Linux上天之路(十二)之服务管理
主要内容 服务介绍 独立服务 非独立服务 1. 服务介绍 服务:常驻在内存中的程序,且可以提供一些系统或网络功能,那就是服务. 计算机中的系统服务有很多,比如: apache提供web服务 ftp提供 ...
- 基于Spring实现策略模式
背景: 看多很多策略模式,总结下来实现原理大体都差不多,在这里主要是讲解下自己基于Spring更优雅的实现方案:这个方案主要是看了一些开源rpc和Spring相关源码后的一些思路,所以在此进行总结 首 ...
- kafka学习笔记(一)消息队列和kafka入门
概述 学习和使用kafka不知不觉已经将近5年了,觉得应该总结整理一下之前的知识更好,所以决定写一系列kafka学习笔记,在总结的基础上希望自己的知识更上一层楼.写的不对的地方请大家不吝指正,感激万分 ...
- elasticsearch之集成中文分词器
IK是基于字典的一款轻量级的中文分词工具包,可以通过elasticsearch的插件机制集成: 一.集成步骤 1.在elasticsearch的安装目录下的plugin下新建ik目录: 2.在gith ...
- 服务监控 | 彻底搞懂Dropwizard Metrics一篇就够了
Metrics是一个提供服务性能检测工具的Java类库,它提供了功能强大的性能指标工具库用于度量生产环境中的各关键组件性能. 度量类型 Metrics提供了以下几种基本的度量类型: Gauge:用于提 ...
- Selenium2+python自动化65-js定位几种方法总结
Selenium2+python自动化65-js定位几种方法总结 前言 本篇总结了几种js常用的定位元素方法,并用js点击按钮,对input输入框输入文本 一.以下总结了5种js定位的方法 除了i ...
- 使用HTMLTestRunner在目标目录下并未生成HTML文件解决办法
使用pycharm工具应用HTMLTestRunner模块时,测试用例可以顺利运行,但在目标目录下并未生成HTML文件.使用python的IDLE,能够正常运行并创建写入测试结果. 测试环境:pyth ...
- 《剑指offer》面试题29. 顺时针打印矩阵
问题描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字. 示例 1: 输入:matrix = [[1,2,3],[4,5,6],[7,8,9]] 输出:[1,2,3,6,9,8,7,4 ...