【BZOJ3244】【NOI2013】树的计数(神仙题)
【BZOJ3244】【NOI2013】树的计数(神仙题)
题面
这题有点假,\(bzoj\)上如果要交的话请输出\(ans-0.001,ans,ans+0.001\)
题解
数的形态和编号没有关系,因此对于\(bfs\)序重标号,同时修改一下\(dfs\)序方便做题。
因为\(bfs\)的层数等于树高,所以我们相当于要把\(bfs\)划分为若干段,
那么,每一种\(bfs\)划分显然要么不合法,要么对应一种树的形态。
那么,我们来考虑\(bfs\)划分的几个限制。
首先有一个很明显的限制:
如果划分了一段\([L,R]\),那么\(dfn[L]<dfn[L+1]<...<dfn[R]\)
原因很简单,因为一个点的所有儿子对应的出现顺序在\(bfs\)和\(dfs\)序中相同
显然所有儿子都是从左往右遍历,因此这一项显然成立。
令\(pos\)为\(dfs\)序的反数组,
考虑\(dfs\)序中相邻的两个元素\(x,x+1\)。
显然要么是父子关系,要么是兄弟关系,要么\(x+1\)是\(x\)祖先的儿子。
所以可以列出不等式\(dep[x+1]\le dep[x]+1\)
当然了,还有一个约束,根节点后面必须断开。
我们构建一个数组\(s\),\(s[i]=1\)的话就表示\(i\)和\(i+1\)必须断开
归类一下,约束条件有三项:
1.根节点后面必须断开,而根节点一定是\(bfs\)序中的\(1\)
2.同一段\([l,r]\)中的所有点满足\(dfs\)序递增,即如果\(pos[i]>pos[i+1]\),那么必须断开,也就是\(s[i]=1\)
3.如果\(dfn[i]<dfn[i+1]\),那么,\(\sum_{j=dfn[i]}^{dfn[i+1]-1} s[i]\le 1\),这个式子在计算的时候需要满足\(dfn[i]\lt dfn[i+1]\),而根据推导\(dep[i+1]-dep[i]\le 1\)。
如果知道了\(s\),那么\(1+\sum s[i]\)就是树高,也就是\(bfs\)序分开的段数。
考虑一下贡献是怎么产生的。
两个相邻的\(bfs\)序之间要么不能断开,贡献为\(0\)
要么必须断开,贡献为\(1\)
要么随意,贡献为\(0.5\)
只需要利用所有约束条件确定每个位置的贡献就好啦。
我是看得LCF学长的blog
#include<iostream>
#include<cstdio>
using namespace std;
#define RG register
#define MAX 222222
inline int read()
{
RG int x=0,t=1;RG char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=-1,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return x*t;
}
double ans;
int n,a[MAX],d[MAX],s[MAX];
int main()
{
n=read();ans=1;s[1]=1;s[2]=-1;
for(int i=1;i<=n;++i)a[d[i]=read()]=i;
for(int i=1;i<=n;++i)d[a[read()]]=i;
for(int i=1;i<=n;++i)a[d[i]]=i;
for(int i=2;i<=n;++i)if(a[i]<a[i-1])s[i-1]++,s[i]--,++ans;
for(int i=2;i<=n;++i)if(d[i-1]<d[i]-1)s[d[i-1]]++,s[d[i]]--;
for(int i=1,t=0;i<n;++i)t+=s[i],ans+=(!t)?0.5:0;
printf("%.3lf\n",ans+1);
return 0;
}
【BZOJ3244】【NOI2013】树的计数(神仙题)的更多相关文章
- BZOJ3244 NOI2013树的计数(概率期望)
容易发现的一点是如果确定了每一层有哪些点,树的形态就确定了.问题变为划分bfs序. 考虑怎样划分是合法的.同一层的点在bfs序中出现顺序与dfs序中相同.对于dfs序中相邻两点依次设为x和y,y至多在 ...
- [BZOJ3244][NOI2013]树的计数
这题大家为什么都写O(NlogN)的算法呢?…… 让本蒟蒻来写一个O(N)的吧…… 首先还是对BFS序和DFS序重编号,记标好的DFS序为d[1..n].令pos[x]为x在d[]中出现的位置,即po ...
- [bzoj3244][noi2013]树的计数 题解
UPD: 那位神牛的题解更新了,在这里. ------------------------------------------------------------------------------- ...
- BZOJ3244 [Noi2013]树的计数 【数学期望 + 树遍历】
题目链接 BZOJ3244 题解 不会做orz 我们要挖掘出\(bfs\)序和\(dfs\)序的性质 ①容易知道\(bfs\)序一定是一层一层的,如果我们能确定在\(bfs\)序中各层的断点,就能确定 ...
- [UOJ#122][NOI2013]树的计数
[UOJ#122][NOI2013]树的计数 试题描述 我们知道一棵有根树可以进行深度优先遍历(DFS)以及广度优先遍历(BFS)来生成这棵树的 DFS 序以及 BFS 序.两棵不同的树的 DFS 序 ...
- 【BZOJ3244】【UOJ#122】【NOI2013]树的计数
NOI都是酱的题怎么玩啊,哇.jpg 原题: 我们知道一棵有根树可以进行深度优先遍历(DFS)以及广度优先遍历(BFS)来生成这棵树的DFS序以及BFS序.两棵不同的树的DFS序有可能相同,并且它们的 ...
- [bzoj3244] [洛谷P1232] [Noi2013] 树的计数
Description 我们知道一棵有根树可以进行深度优先遍历(DFS)以及广度优先遍历(BFS)来生成这棵树的DFS序以及BFS序.两棵不同的树的DFS序有可能相同,并且它们的BFS序也有可能相同, ...
- BZOJ3244/UOJ122 [Noi2013]树的计数
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...
- 洛谷 P5280 - [ZJOI2019]线段树(线段树+dp,神仙题)
题面传送门 神仙 ZJOI,不会做啊不会做/kk Sooke:"这八成是考场上最可做的题",由此可见 ZJOI 之毒瘤. 首先有一个非常显然的转化,就是题目中的"将线段树 ...
- 3244: [Noi2013]树的计数 - BZOJ
Description 我们知道一棵有根树可以进行深度优先遍历(DFS)以及广度优先遍历(BFS)来生成这棵树的DFS序以及BFS序.两棵不同的树的DFS序有可能相同,并且它们的BFS序也有可能相同, ...
随机推荐
- MAVEN相关文章
Maven入门指南① :Maven 快速入门及简单使用 Maven入门指南② :Maven 常用命令,手动创建第一个 Maven 项目 Maven入门指南③:坐标和依赖 Maven入门指南④:仓库 M ...
- ffmpeg 踩坑实录 近期使用总结(三)
一.背景介绍 将ffmpeg运用到项目上已经有一段时间了,趁现在有空赶紧记下来. 二.技术点总结 2.1 实现方式 项目里面主要运用的形式是,在java端,调用操作系统的方法,并执行切片命令. ...
- katalon系列九:DEBUG调试功能
Katalon Studio做为一个IDE,具有和其他IDE一样的Debug功能,可以让我们方便的调试代码.将脚本切换到Script模式,在你想设断点的行首双击,或右击选择:(Groovy)Toggl ...
- RabbitMQ入门:在Spring Boot 应用中整合RabbitMQ
在上一篇随笔中我们认识并安装了RabbitMQ,接下来我们来看下怎么在Spring Boot 应用中整合RabbitMQ. 先给出最终目录结构: 搭建步骤如下: 新建maven工程amqp 修改pom ...
- Loadrunner教程--常用操做流程
1loadrunner压力测试一般使用流程 1.1loadrunner压力测试原理 本质就是在loadrunner上模拟多个用户同时按固定行为访问web站点.其中固定行为在loadrunner中是通过 ...
- Matlab中 .' 的作用。
Syntax B = A.' B = transpose(A) Description B = A.' returns the nonconjugate transpose of A, that ...
- mtv网站架构模式适合企业网站应用吗?
mtv网站架构模式适合企业网站应用吗?有时候在思考这样一个问题. 从开发角度来说,本来mvc的进度慢了些,如果在数据库管理方面用sql的话,管理起来也不很方便.小企业网本来数据就不很多,也没什么太多安 ...
- Centos7下安装Oracle11g r2
我的centos7是在virtualbox下安装的,安装Oracle安装了好久好久,最开始的时候在网上找的两个文章,按照步骤装,有一篇写着装的时候有灰色的竖线,直接按space键或者鼠标右键close ...
- 工作在Amazon:为何晋升如此难?
英文原文:Why It's So Difficult to Climb Amazon's Corporate Ladder 本文作者 Brad Stone 的新书 The Everything Sto ...
- Alpha阶段第2周/共2周 Scrum立会报告+燃尽图 02
此次作业要求参见 [https://edu.cnblogs.com/campus/nenu/2018fall/homework/2285] Scrum master:祁玉 一.小组介绍 组长:王一可 ...