CF 1025 D. Recovering BST
D. Recovering BST
http://codeforces.com/contest/1025/problem/D
题意:
给出一个连续上升的序列a,两个点之间有边满足gcd(ai ,aj) != 1。选择一些边,问是否能构成一棵有n个点的二叉搜索树。
分析:
区间dp。
每个子树都是一段连续的区间,L[i][j]表示j为根,i~j-1这个区间的点能否使j的左子树,R[i][j]:i为根,i+1~j这个区间能否为i的右子树。
枚举一个中间点作为根,转移即可。
为什么这样转移:直接f[i][j]表示区间i~j能否构成一个树的话,还要去枚举根,或者记录根。就变成了f[i][j][k]表示区间i~j,根为k能否成为一棵树。这样复杂度就太大了。换一种记录根的方式,只记录左边和右边,两边是互不影响的,前面的状态拆成了两个,现在就不需要枚举根了。
代码:
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<iostream>
#include<cctype>
#include<set>
#include<vector>
#include<queue>
#include<map>
#define fi(s) freopen(s,"r",stdin);
#define fo(s) freopen(s,"w",stdout);
using namespace std;
typedef long long LL; inline int read() {
int x=,f=;char ch=getchar();for(;!isdigit(ch);ch=getchar())if(ch=='-')f=-;
for(;isdigit(ch);ch=getchar())x=x*+ch-'';return x*f;
} const int N = ; LL a[N];
bool L[N][N], R[N][N], e[N][N]; LL gcd(LL a,LL b) {
return b == ? a : gcd(b, a % b);
} int main() { int n = read();
for (int i = ; i <= n; ++i) {
a[i] = read();
L[i][i] = R[i][i] = ;
}
for (int i = ; i <= n; ++i)
for (int j = i + ; j <= n; ++j)
if (gcd(a[i], a[j]) > ) e[i][j] = e[j][i] = ; for (int k = ; k <= n; ++k) {
for (int i = , j; (j = i + k - ) <= n; ++i) {
for (int mid = i; mid <= j; ++mid) {
if (L[i][mid] && R[mid][j])
R[i - ][j] |= e[i - ][mid], L[i][j + ] |= e[mid][j + ];
}
}
} for (int i = ; i <= n; ++i) {
if (L[][i] && R[i][n]) {
puts("Yes"); return ;
}
}
puts("No");
return ;
}
CF 1025 D. Recovering BST的更多相关文章
- Codeforces 1025 D - Recovering BST
		D - Recovering BST 思路:区间dp dp[l][r][0]表示l到r之间的数字可以构成一个二叉搜索树,并且以r+1为根节点 dp[l][r][0]表示l到r之间的数字可以构成一个二叉 ... 
- Solution -「CF 1025D」Recovering BST
		\(\mathcal{Description}\) Link. 给定序列 \(\{a_n\}\),问是否存在一棵二叉搜索树,使得其中序遍历为 \(\{a_n\}\),且相邻接的两点不互素. ... 
- CF D. Recovering BST (区间DP)
		题意:给你n个节点,每个节点有一个权值,两个点可以连边当且仅当这两个点的gcd>1,问你这n个点能否构成一个二叉搜索树(每个节点最多有两个儿子,且左儿子小于右儿子),输入为递增顺序. 分析: 若 ... 
- CF1025D Recovering BST
		题意:给定序列,问能否将其构成一颗BST,使得所有gcd(x, fa[x]) > 1 解:看起来是区间DP但是普通的f[l][r]表示不了根,f[l][r][root]又是n4的会超时,怎么办? ... 
- D. Recovering BST Codeforces Round #505 (rated, Div. 1 + Div. 2, based on VK Cup 2018 Final)
		http://codeforces.com/contest/1025/problem/D 树 dp 优化 f[x][y][0]=f[x][z][1] & f[z+1][y][0] ( gcd( ... 
- Codeforces Round #505 D. Recovering BST(区间DP)
		首先膜一发网上的题解.大佬们tql. 给你n个单调递增的数字,问是否能够把这些数字重新构成一棵二叉搜索树(BST),且所有的父亲结点和叶子结点之间的gcd > 1? 这个题场上是想暴力试试的.结 ... 
- Recovering BST CodeForces - 1025D (区间dp, gcd)
		大意: 给定$n$个数, 任意两个$gcd>1$的数间可以连边, 求是否能构造一棵BST. 数据范围比较大, 刚开始写的$O(n^3\omega(1e9))$竟然T了..优化到$O(n^3)$才 ... 
- 「CF1025D Recovering BST」
		题目 郑州讲过的题了 发现这是一个二叉搜索树,给出的还是中序遍历,我们很自然的想到我们需要可以用一个\(f[i][j][k](k\in[i,j])\)来表示区间\([i,j]\)能不能形成以\(k\) ... 
- CodeForces - 1025D: Recovering BST (区间DP)
		Dima the hamster enjoys nibbling different things: cages, sticks, bad problemsetters and even trees! ... 
随机推荐
- POJ3304 Segments
			嘟嘟嘟 题面就不说了,网上都有. 刚开始理解成了只要有不孤立的线段就算合法,结果就不会了--然而题中要求是所有线段至少有一个交点. 其实想一想就知道,问题转化为了是否存在一条直线和所有线段都有交点. ... 
- ArcFac_C#_DEMO开发
			手上有一个项目,需要检验使用本程序的,是否本人!因为在程序使用前,我们都已经做过头像现场采集,所以源头呢是不成问题的,那么人脸检测,人脸比对,怎么办呢?度娘了下,目前流行的几个人脸检测,人脸比对核心, ... 
- docker-4-镜像
			是什么 镜像是一种轻量级.可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件, 它包含运行某个软件所需的所有内容,包括代码.运行时.库.环境变量和配置文件. 1.UnionFS(联合文件 ... 
- ethereumjs/merkle-patricia-tree-2-API
			SecureTrie src/secure.js:10-15 Extends Trie 扩展前缀树 You can create a secure Trie where the keys are au ... 
- Centos7 KDE 桌面Konsole 光标错位解决方法
			在使用linux 系统,桌面为KDE 时,在使用Konsole 时,光标的位置是错位的. 如下图效果 解决办法 用命令进入/home/cfox/.kde/share/apps/konsole 修改S ... 
- 深入学习c++--重新审视auto
			1. auto推断变量类型 2. auto遍历 3. 自定义类可使用auto 
- Java泛型 PECS(Producer Extends, Consumer Super)
			本文转载自ImportNew,原文链接 Java 泛型: 什么是PECS(Producer Extends, Consumer Super) PECS指“Producer Extends,Consum ... 
- Java SPI(Service Provider Interface)
			SPI 全称为 (Service Provider Interface) ,是JDK内置的一种服务提供发现机制. 目前有不少框架用它来做服务的扩展发现, 简单来说,它就是一种动态替换发现的机制, 举个 ... 
- openstack neutron 简单理解
			分析1)位于最上层的Neutron Server充当一个门派中的“掌门人”角色(RESTful Server),负责接受来自外部门派(项目)的API请求,比如Nova API创建网络的请求.2)位于中 ... 
- #ifdef 和 #if defined的区别
			#ifdef 和 #if defined的区别在于,后者可以组成复杂的预编译条件,比如 #if defined (AAA) && defined (BBB)xxxxxxxxx#endi ... 
