考场

\(65+5+0\),并列 rk2

最高分 \(55+10+10\)

T1:等比数列可以写作 \(q^kx\),发现 \(q\le1000\) 且有一档分为 \(a_i\le100\),想到 \(2^{60}>10^{18}\),即等比数列的长度最多为 \(59\),这样枚举的区间就从 \(n^2\) 下降到了 \(60n\)。对于每个区间,排序后枚举 \(q\),通过预处理 \(q\) 的次幂大力剪枝,复杂度不明。写了很久,最终有RE有TLE。

T3:虽然以前学过欧拉路,但之后再没写过,忘得只剩下题目给出的定义。发现自己会的暴力是 \(O(2^{n(n-1)/2}m),(m为边数)\),没有分(其实可以打表)手玩小数据无果就放弃了。hkh的20pts是正解,但把某个快速幂的地方写成了 1ll<<

T2:猜到是树形DP,但只剩下1h了,加上部分分有40pts,就决定放弃写正解。先写了菊花图的分,暴力写挂了。知道最后10min才意识到我的写法(边dfs边枚举重儿子)会在枚举完重儿子后只能在这个子树里走,导致有些答案统计不上。wcr的DP是假的,过了二叉树的点和其他一些点,45pts

sol

序列

如果要对区间排序,复杂度至少是 \(O(60n)\),再加上判断是否等比,肯定过不去。因此正解利用等比数列的性质规避了排序。

等比数列的公比开 \(n\) 次根也一定是该数列的公比

等比数列中任意两数之商是公比的 \(n\) 次

因此枚举 \(q\),记录下每个数开 \(n\) 次根的最小整数是多少,然后直接用两个原数列中相邻的数就可以确定公比(公比越小越容易加入数)

ycx依据 \(q\) 很小,有另一种做法(但时间复杂度劣)

code
const int N = 1e5+5;
const LL X = 1000000000000000000ll;
int n;
LL a[N]; int ans;
map<LL,int> minq;
map<LL,bool> vis; int main() {
For(i,2,1000)
for(LL j = 1; j <= X/i; j *= i)
if( !minq[j*i] ) minq[j*i] = i; // 记录开n次根的最小整数
read(n);
For(i,1,n) read(a[i]);
for(int i = 2, j = 1; i <= n+1; ++i)
if( a[i] == a[i-1] ) ++j;
else ans = max(ans,j), j = 1; // 特判q=1
for(int i = 1; i < n; ++i) {
vis.clear(); // 记录这个数字是否出现过
LL mn = min(a[i],a[i+1]), mx = max(a[i],a[i+1]);
if( mn == mx || mx % mn ) continue;
vis[mn] = vis[mx] = 1;
LL q = minq[mx/mn];
ans = max(ans,2);
for(int j = i+2; j <= n; ++j) {
if( vis[a[j]] ) break; // 公比不为1的等比数列中不能有相同的数字
vis[a[j]] = 1;
mn = min(a[j],a[j-1]), mx = max(a[j],a[j-1]);
if( mx % mn || minq[mx/mn] != q ) break;
ans = max(ans,j-i+1);
}
}
printf("%d\n",ans);
return 0;
}

熟练剖分(tree)

树形DP神题。发现如果直接DP的话祖先节点对重儿子的选择会影响子树的最长轻链长,于是考虑固定子树最长轻链长来计算出现的概率。

设 \(f[u,i]\) 为 \(u\) 的子树中到 \(u\) 的最长轻链长 \(i\) 的概率,答案为 \(\sum_{i=0}^ni\times f[rt,i]\)(长度乘概率)

第一维枚举重儿子 \(son\),第二维枚举儿子 \(v\),第三维枚举轻链长,这样可以通过子树的长度来推 \(u\) 的。考虑转移:设 \(g[k]\) 为 \(u\) 前面儿子中到 \(u\) 轻链长为 \(k\) 的概率,分类讨论:

  • \(son=v\):

    • \(v\) 子树链长 \(k\):\(+f[v,k]\times\sum_{i=1}^kg[k]\)(\(v\) 长 \(k\),其他不超过 \(k\))
    • 其他子树链长 \(k\):\(+g[k]\times\sum_{i=1}^kf[v,k]\)
    • 两部分都为 \(k\) 时有重复:\(-f[v,k]\times g[k]\)
  • \(son\neq v\):类似。只是注意此时 \((u,v)\) 为轻边,到 \(u\) 为 \(k\) 时到 \(v\) 为 \(k-1\)

实现:发现 \(\sum\) 会增加时间复杂度,因此对 \(f[u],g\) 作前缀和,注意在调用单点值时还原。

时间复杂度 \(O(n^2)\)(证明类似树形背包)

code
const int N = 3e3+5, p = 1e9+7;
int n;
vector<int> to[N]; int rt,fa[N],siz[N];
LL ans,f[N][N],g[N],h[N]; LL Pow(LL x,LL y)
{ LL res=1; for(;y;y>>=1,x=x*x%p)if(y&1)res=res*x%p; return res; } void dfs(int u) {
siz[u] = 1;
for(int v : to[u])
dfs(v), siz[u] += siz[v];
int tot = Pow(to[u].size(),p-2);
for(int son : to[u]) {
For(j,0,n) g[j] = 1;
for(int v : to[u]) {
For(k,0,siz[v]+1) {
// 计算g[k]时要用g[k-2..k],不能直接覆盖,要用h先存下来
LL gk = g[k]; // g[k]单点值d
if( k ) gk -= g[k-1];
if( son == v ) {
LL fk = f[v][k];// f[v][k]单点值
if( k ) fk -= f[v][k-1];
h[k] = (fk*g[k]%p + f[v][k]*gk%p - fk*gk%p +p)%p;
} else {
LL fk1 = f[v][k-1]; // f[v][k-1]单点值
if( k > 1 ) fk1 -= f[v][k-2];
h[k] = (fk1*g[k]%p + f[v][k-1]*gk%p - fk1*gk%p +p)%p;
// u-v为轻边,到u为k即到v为k-1
}
}
g[0] = h[0], h[0] = 0;
For(k,1,siz[v]+1) g[k] = (g[k-1] + h[k]) %p, h[k] = 0;
// h[k]为=k的概率, g[k]为<=k的
}
for(int j = siz[u]; j; --j) g[j] = (g[j] - g[j-1] +p) %p;
For(j,0,siz[u]) f[u][j] = (f[u][j] + g[j] * tot) %p;
}
if( !to[u].size() ) f[u][0] = 1;
For(i,1,siz[u]+1) f[u][i] = (f[u][i] + f[u][i-1]) %p; // f[u][i]为<=i的
} int main() {
read(n);
For(i,1,n) {
int son; read(son);
For(j,1,son) {
int x; read(x);
to[i].PB(x), fa[x] = i;
}
}
For(i,1,n) if( !fa[i] ) { rt = i; break; }
dfs(rt);
For(i,1,n) ans = (ans + i * (f[rt][i]-f[rt][i-1]+p)%p)%p;
printf("%lld",ans);
return 0;
}

建造游乐园(play)

首先要知道一些性质:

无向图度数为奇数的点有偶数个

欧拉图(有欧拉回路的图)中所有点的度数均为偶数

本题只给定点数,考虑从 \(1..i-1\) 个点推到 \(i\) 个点。设 \(f_i\) 为 \(i\) 个点的答案,\(g_i\) 为 \(i\) 个点不考虑连通性的答案,转移:

\[g_i=2^{\binom {i-1}2}
\]
\[f_i=g_i-\sum_{j=1}^{i-1}f_j\times g_{i-j}\times\binom{i-1}{j-1}
\]

解释:

\(g_i\):先用 \(i-1\) 个点随便连边,对于其中度数为奇数的再和剩下的 \(1\) 个点连边。

\(f_i\):在 \(g_i\) 的基础上减掉不连通的情况。

枚举点 \(1\) 所在连通块的大小 \(j\),则不用管剩下的 \(i-j\) 个点连不连通(因为这两部分一定不连通)

由于图有编号,而 \(f_j\) 只能统计出第一部分编号为 \(1..j\) 的,于是考虑用组合数算出编号的轮换。由于点 \(1\) 固定,因此组合数上下都 \(-1\)

时间复杂度 \(O(n^2)\)。

事实上,本题的式子类似 城市规划,只是不考虑联通性的答案 \(g_i\) 不同。因此理论上可以用fft做到 \(O(n\log n)\)

code
const int N = 2e3+5, p = 1e9+7;
int n; LL C[N][N],f[N],g[N]; LL Pow(LL x,LL y)
{ LL res=1; for(;y;y>>=1,x=x*x%p)if(y&1)res=res*x%p; return res; } int main() {
read(n);
For(i,0,n) {
C[i][0] = 1;
For(j,1,i) C[i][j] = (C[i-1][j-1] + C[i-1][j]) %p;
}
For(i,1,n) {
f[i] = g[i] = Pow(2,C[i-1][2]);
for(int j = 1; j < i; ++j)
f[i] = (f[i] - f[j] * g[i-j] %p * C[i-1][j-1] %p +p)%p;
}
printf("%lld",f[n]*C[n][2]%p);
return 0;
}

20210501 序列,熟练剖分(tree),建造游乐园(play)的更多相关文章

  1. 熟练剖分(tree) 树形DP

    熟练剖分(tree) 树形DP 题目描述 题目传送门 分析 我们设\(f[i][j]\)为以\(i\)为根节点的子树中最坏时间复杂度小于等于\(j\)的概率 设\(g[i][j]\)为当前扫到的以\( ...

  2. NOIP模拟测试3「序列·熟练剖分·建造游乐园(play)」

    ---恢复内容开始--- 序列 刚调出来样例就A了,假装是水题. 因为是乱序,我们要求出来每两项之间最小公比,而不是直接比 求出来每两项之间最小公比,然后扫一遍就完了.(还要注意重复情况) 那么问题就 ...

  3. HZOI2019熟练剖分(tree)

    题目大意:https://www.cnblogs.com/Juve/articles/11186805.html 题解: 先给出官方题解: 其实这题跟期望没什么关系,因为E=$\sum_\limits ...

  4. 【模拟7.14】B. 熟练剖分(tree) (概率DP)

    一道概率神题,考试时没读清题考完看了学长的玄学题解看了好几个小时 首先f[i][j]表示在点 i 为根的子树中,向下最长轻链长度小于等于 j 的概率. 首先递归下去并求出子树大小,然后枚举重儿子,枚举 ...

  5. 模拟3题解 T3建造游乐园

    T3建造游乐园 这题的关键是推式子 i个点中,有g[i]个方案是度为偶数但不一定连通那么就要减去不合法的设已有j个合法,其个数为f[j],剩下i-j个的方案数是g[i-j]选出来一个固定的点在合法的j ...

  6. BZOJ 2758 Blinker的噩梦(扫描线+熟练剖分+树状数组)

    题目链接:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2758 题意:平面上有n个多边形(凸包和圆).任意两个多边形AB只有两种关系:(1) ...

  7. BZOJ 3672 [Noi2014]购票 (熟练剖分+凸壳维护)

    题目链接:http://www.lydsy.com:808/JudgeOnline/problem.php?id=3672 题意:给出一棵有根树(1为根),边有长度.每个点u有三个属性(len[u], ...

  8. [NOIP模拟测试3] 建造游乐园 题解(欧拉图性质)

    Orz 出题人石二队爷 我们可以先求出有n个点的联通欧拉图数量,然后使它删或增一条边得到我们要求的方案 也就是让它乘上$C_n^2$ (n个点里选2个点,要么删边要么连边,选择唯一) 那么接下来就是求 ...

  9. HZOI2019建造游乐园(play)组合数学,欧拉图

    题目:https://www.cnblogs.com/Juve/articles/11186805.html(密码是我的一个oj用户名) solution: 反正我是想不出来... 题目大意就是要求出 ...

随机推荐

  1. 抽奖动画 - lao虎机抽奖

    本文介绍一个lao虎机抽奖动画的实现,lao虎机抽奖在各类商家营销活动中非常常见,这里主要介绍动画的实现过程,其他细节不做详细分析. ps:lao虎机是敏感词,博客园不允许出现,所有老用拼音. 1. ...

  2. noip模拟32[好数学啊]

    noip模拟32 solutions 真是无语子,又没上100,无奈死了 虽然我每次都觉得题很难,但是还是有好多上100的 战神都200多了,好生气啊啊啊 从题开始变难之后,我的时间分配越来越不均匀, ...

  3. DOS命令--Windows操作系统之母

    DOS命令 DOS是什么 解释:Disk Operating System的缩写,意思是"磁盘操作系统" 系统:DOS就是人给机器下达命令的集合,是存储在操作系统中的命令集 基本用 ...

  4. 小白学习Vue第五天(v-model实用的地方)

    用法一radio单选项 <!-- 添加name男女选项互斥 --> <label for="male"> <input type="radi ...

  5. MobSF移动安全扫描平台本地化部署与简单汉化

    在之前的文章MobSF移动安全扫描平台环境搭建与试用中,我们用docker进行了搭建,那么我们如何在本地直接搭建呢,其实也是很简单的. 本地化部署 我们在本地安装 其实是很简单的,里面有两个文件,在不 ...

  6. 实战爬取Plati官网游戏实时最低价格-Python

    需要修改url中的id_r="这个",这个id需要从Battlefield V (plati.ru)中获取,其实也是这个链接中的#s24235. 配合了e-mail推送,其实这个e ...

  7. 解决vscode+python不提示numpy函数的问题

    前言 使用vscode编写numpy代码时,对于numpy.array()等方法总是无法提示.查找了很多博客后,大部分都是修改配置和安装多种vscode插件,经过尝试后方法对于我来说无效.最后在调试p ...

  8. Elasticsearch核心技术(二):Elasticsearch入门

    本文从基本概念.基本CRUD操作.倒排索引原理.分词等部分来初识Elasticsearch. 2.1 基本概念 Elasticsearch是面向文档(Document)的,文档是所有可搜索数据的最小单 ...

  9. Maven 下载、安装与配置

    一.需要准备的东西 确定电脑上已经成功安装JDK 二.下载与安装 1. 前往https://maven.apache.org/download.cgi下载最新版的Maven程序: 注意:Maven3. ...

  10. AWS(amazon ec2)服务器流量查询

    aws ec2流量监控 亚马逊云服务新用户绑定信用卡免费使用一年,相信很多人白嫖过,选用micro最低配置+流量免费15G,包含上下行.这种配置用来测试玩玩还行,生产使用的话容易超标.很多人想知道流量 ...