【BZOJ3244】【NOI2013】树的计数(神仙题)

题面

BZOJ

这题有点假,\(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】树的计数(神仙题)的更多相关文章

  1. BZOJ3244 NOI2013树的计数(概率期望)

    容易发现的一点是如果确定了每一层有哪些点,树的形态就确定了.问题变为划分bfs序. 考虑怎样划分是合法的.同一层的点在bfs序中出现顺序与dfs序中相同.对于dfs序中相邻两点依次设为x和y,y至多在 ...

  2. [BZOJ3244][NOI2013]树的计数

    这题大家为什么都写O(NlogN)的算法呢?…… 让本蒟蒻来写一个O(N)的吧…… 首先还是对BFS序和DFS序重编号,记标好的DFS序为d[1..n].令pos[x]为x在d[]中出现的位置,即po ...

  3. [bzoj3244][noi2013]树的计数 题解

    UPD: 那位神牛的题解更新了,在这里. ------------------------------------------------------------------------------- ...

  4. BZOJ3244 [Noi2013]树的计数 【数学期望 + 树遍历】

    题目链接 BZOJ3244 题解 不会做orz 我们要挖掘出\(bfs\)序和\(dfs\)序的性质 ①容易知道\(bfs\)序一定是一层一层的,如果我们能确定在\(bfs\)序中各层的断点,就能确定 ...

  5. [UOJ#122][NOI2013]树的计数

    [UOJ#122][NOI2013]树的计数 试题描述 我们知道一棵有根树可以进行深度优先遍历(DFS)以及广度优先遍历(BFS)来生成这棵树的 DFS 序以及 BFS 序.两棵不同的树的 DFS 序 ...

  6. 【BZOJ3244】【UOJ#122】【NOI2013]树的计数

    NOI都是酱的题怎么玩啊,哇.jpg 原题: 我们知道一棵有根树可以进行深度优先遍历(DFS)以及广度优先遍历(BFS)来生成这棵树的DFS序以及BFS序.两棵不同的树的DFS序有可能相同,并且它们的 ...

  7. [bzoj3244] [洛谷P1232] [Noi2013] 树的计数

    Description 我们知道一棵有根树可以进行深度优先遍历(DFS)以及广度优先遍历(BFS)来生成这棵树的DFS序以及BFS序.两棵不同的树的DFS序有可能相同,并且它们的BFS序也有可能相同, ...

  8. BZOJ3244/UOJ122 [Noi2013]树的计数

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...

  9. 洛谷 P5280 - [ZJOI2019]线段树(线段树+dp,神仙题)

    题面传送门 神仙 ZJOI,不会做啊不会做/kk Sooke:"这八成是考场上最可做的题",由此可见 ZJOI 之毒瘤. 首先有一个非常显然的转化,就是题目中的"将线段树 ...

  10. 3244: [Noi2013]树的计数 - BZOJ

    Description 我们知道一棵有根树可以进行深度优先遍历(DFS)以及广度优先遍历(BFS)来生成这棵树的DFS序以及BFS序.两棵不同的树的DFS序有可能相同,并且它们的BFS序也有可能相同, ...

随机推荐

  1. EmitMapper自动映射工具

             在实体与DTO之间,我们一般都需要进行映射.如果手动的来进行转换,实在是太麻烦.所以就产生了很多映射工具,比如AutoMapper,EmitMapper.而经过一些对比,EmitMa ...

  2. MyBatis.Net 配置

    假设我们现在有这样的需求,要对学生信息进行管理 学生表有要以下要求 字段名称 数据类型 说明 stuNo 字符 学号,该列必填,为主键递增 stuName 字符 学生姓名,该列必填,要考虑姓氏可能是两 ...

  3. katalon系列十三:5.10新增跳过用例&命令行赋值全局变量

    Katalon Studio升级到5.10版本了,这次新增了2个很实用的功能:一.跳过用例在Listener中新增了跳过用例方法,Listener类似于JUnit4的annotation中的@Befo ...

  4. windows下Mysql安装启动及常用操作

    1.下载mysql https://dev.mysql.com/downloads/ 2.配置环境变量 变量名:MYSQL_HOME 变量值:E:\MySql\mysql-8.0.15-winx64\ ...

  5. 使用Photon引擎进行unity网络游戏开发(三)——网络游戏大厅及房间

    使用Photon引擎进行unity网络游戏开发(三)--网络游戏大厅及房间 Photon PUN Unity 网络游戏开发 连接到Photon ConnectUsingSettings 设置你的客户端 ...

  6. leetcode-优美的排列

    假设有从 1 到 N 的 N 个整数,如果从这 N 个数字中成功构造出一个数组,使得数组的第 i 位 (1 <= i <= N) 满足如下两个条件中的一个,我们就称这个数组为一个优美的排列 ...

  7. 前端之JavaScript(二)

    一.概述 本篇主要介绍JavaScript的BOM和DOM操作,在前端之JavaScript(一)中介绍了JavaScript基础知识 1.1.BOM和DOM BOM(Browser Object M ...

  8. JavaScript学习笔记(五)——类型、转换、相等、字符串

    第六章 类型 相等 转换等 一.类型 1 typeof(); typeof是一个内置的JavaScript运算符,可用于探测其操作数的类型. 例: <script language=" ...

  9. C#中的Split用法以及详解

    一.String.Split方法提供了如下6个重载函数: 名称 说明 String.Split (Char[]) 返回包含此实例中的子字符串(由指定 Char 数组的元素分隔)的 String 数组. ...

  10. SQLSERVER 根据身份证号码 往出生年月日 赋值

    update CREW_SailorInfo set DT_DOB= ( case then , ) then , ) else null end) 注:此问题仅供参考 如有疑问 请加QQ群18153 ...