「ZJOI2015」地震后的幻想乡 解题报告
「ZJOI2015」地震后的幻想乡
想了半天,打开洛谷题解一看,最高票是_rqy的,一堆密密麻麻的积分差点把我吓跑。
据说有三种解法,然而我只学会了一种最辣鸡的凡人解法。
题意:给一个无向图\(G\),边权为\([0,1]\)间的实数,求这个图的最小生成树的最大边权期望。
提示:对于 \(n\) 个 \([0,1]\) 之间的随机变量 \(x_1,x_2,\dots,x_n\),第 \(k\) 小的那个的期望值是 \(\frac{k}{n+1}\)。
考虑使用这个提示来帮助解题。
首先有一个暴力做法,枚举边权的相对大小,然后做最小生成树,kruskal得到一棵树时拿提示算一下
这个想法启发我们钦定一个边集\(S\)作为前\(|S|\)小,如果这个边集加入第\(|S|\)小这条边时恰好使图联通,我们就可以算它的贡献是\(\frac{|S|}{m+1}\),如果我们还能算出它的方案并除上总方案,我们就可以得到它的概率,所以考虑去统计这个方案。
恰好联通这个条件并不好统计,我们转换一下,可以变成
恰好联通方案=加之前不连通方案-加之后不连通方案
然后比较自然的可以考虑压一个子集去做\(dp\)
令\(f_{S,i},g_{S,i}\)分别表示点集为\(S\),用了\(i\)条边,且点集联通/不连通的方案数,设\(d_S\)为点集\(s\)在图\(G\)中的边数
显然有
\]
考虑\(f\)的递推,我们枚举\(s\)的子集,并且钦定某个点\(k\)一定在子集里,有转移
\]
然后最后考虑如何统计答案,设\(U\)为全集,按照之前说的,答案为
\]
化简一下
\]
Code:
#include <cstdio>
#include <cctype>
#include <algorithm>
using std::min;
template <class T>
void read(T &x)
{
	x=0;char c=getchar();
	while(!isdigit(c)) c=getchar();
	while(isdigit(c)) x=x*10+c-'0',c=getchar();
}
double C[51][51],f[1<<10][51],g[1<<10][51];
int yuu[1<<10],dew[1<<10],n,m;
int main()
{
	read(n),read(m);
	for(int u,v,i=1;i<=m;i++)
	{
		read(u),read(v);
		++dew[(1<<u-1)|(1<<v-1)];
	}
	for(int s=1;s<1<<n;s++)
		for(int t=s;t;t=t-1&s)
			yuu[s]+=dew[t];
	C[0][0]=1;
	for(int i=1;i<=m;i++)
	{
		C[i][0]=1;
		for(int j=1;j<=i;j++)
			C[i][j]=C[i-1][j]+C[i-1][j-1];
	}
	for(int s=1;s<1<<n;s++)
	{
	    for(int i=0;i<=yuu[s];i++)
		{
			for(int t=s-1&s;t;t=t-1&s)
                if(t&(s&-s))
                    for(int j=0;j<=min(i,yuu[t]);j++)
                        f[s][i]+=g[t][j]*C[yuu[s^t]][i-j];
			g[s][i]=C[yuu[s]][i]-f[s][i];
		}
	}
	double ans=0;
	for(int i=0;i<=m;i++) ans+=f[(1<<n)-1][i]/C[m][i];
	ans/=m+1.0;
	printf("%.6f\n",ans);
	return 0;
}
2019.3.5
「ZJOI2015」地震后的幻想乡 解题报告的更多相关文章
- 「SHOI2016」黑暗前的幻想乡 解题报告
		「SHOI2016」黑暗前的幻想乡 sb题想不出来,应该去思考原因,而不是自暴自弃 一开始总是想着对子树做dp,但是状态压不起去,考虑用容斥消减一些条件变得好统计,结果越想越乱. 期间想过矩阵树定理, ... 
- 「ZJOI2015」地震后的幻想乡
		/* 难度最低的解法 钦定一个边集S作为前S小如果这个边集假如第|S|小这条边时加入时S恰好联通, 那么我们就能够算出他的贡献了 恰好联通 = 加了这条边之前不连通方案数 - 加了这条边之后不连通方案 ... 
- 【ZJOI2015】诸神眷顾的幻想乡 解题报告
		[ZJOI2015]诸神眷顾的幻想乡 Description 幽香是全幻想乡里最受人欢迎的萌妹子,这天,是幽香的2600岁生日,无数幽香的粉丝到了幽香家门前的太阳花田上来为幽香庆祝生日. 粉丝们非常热 ... 
- 「SCOI2014」方伯伯的玉米田 解题报告
		#2211. 「SCOI2014」方伯伯的玉米田 发现是取一个最长不下降子序列 我们一定可以把一个区间加的右端点放在取出的子序列的最右边,然后就可以dp了 \(dp_{i,j}\)代表前\(i\)个玉 ... 
- 【LOJ】#2027. 「SHOI2016」黑暗前的幻想乡
		题解 我一开始写的最小表示法写的插头dp,愉快地TLE成60分 然后我觉得我就去看正解了! 发现是容斥 + 矩阵树定理 矩阵树定理对于有重边的图只要邻接矩阵的边数设置a[u][v]表示u,v之间有几条 ... 
- 「SHOI2016」黑暗前的幻想乡
		题目链接 戳我 \(Describe\) \(n−1\)个公司,每个公司能修一些边,求每条边都让不同的公司来修的生成树的方案数 \(Solution\) 这道题很明显容斥.答案就是:所有都选的生成树个 ... 
- loj2027 「SHOI2016」黑暗前的幻想乡
		矩阵树定理+模意义下整数高斯消元 #include <algorithm> #include <iostream> #include <cstring> #incl ... 
- 「USACO11NOV」牛的障碍Cow Steeplechase 解题报告
		题面 横的,竖的线短段,求最多能取几条没有相交的线段? 思路 学过网络流的童鞋在哪里? 是时候重整网络流雄风了! 好吧,废话不多说 这是一道最小割的题目 怎么想呢? 要取最多,那反过来不就是不能取的要 ... 
- LOJ2135 「ZJOI2015」幻想乡战略游戏
		题意 题目描述 傲娇少女幽香正在玩一个非常有趣的战略类游戏,本来这个游戏的地图其实还不算太大,幽香还能管得过来,但是不知道为什么现在的网游厂商把游戏的地图越做越大,以至于幽香一眼根本看不过来,更别说和 ... 
随机推荐
- Shell脚本命令图片
			查看相关文档:shell脚本1 shell脚本2 
- mysql 无法退出sql命令行编辑
			mysql 无法退出sql命令行编辑 | ANBOBhttp://www.anbob.com/archives/579.html mysql 无法退出sql命令行编辑 - 码农甲乙丙 - CSDN博客 ... 
- Bootstrap知识记录:表单和图片
			一.表单Bootstrap 提供了一些丰富的表单样式供开发者使用.1.基本格式//实现基本的表单样式<form><div class="form-group"&g ... 
- Oracle 内存参数调优设置
			Oracle 数据库系统中起到调节作用的参数叫初始化参数,数据库管理员根据实际情况需要适当调整这些 初始化参数以优化Oracle系统. 1 主要系统参数调优介绍 2 系统内存参数的分配 2.1 Ora ... 
- 剑指offer(8)
			题目: 输入一个整数,输出该数二进制表示中1的个数.其中负数用补码表示. 思路: 第一反应想到的是把数右移,每一位与1相与,然后判断个数,但是若输入的为负数,会出现死循环现象. 所以我们设置一个标志量 ... 
- ArrayList的扩容机制
			一.ArrayList的扩容机制 1.扩容的计算方式是向右位移,即:newSize = this.size + (this.size>>1).向右位移,只有在当前值为偶数时,才是除以2:奇 ... 
- Java Json 数据下划线与驼峰格式进行相互转换
			概述 今天遇见一个需求,需要对json数据进行下划线与驼峰格式之间进行转换,在Fastjson.Jackson.Gson都提供了转换的方式,在这里进行一下列举. User类: public class ... 
- js正則表達式
			正則表達式實例化的兩種方式: 字符型 var a=// 對象型var a=new RegExp(,) 修飾符: i:忽略大小寫 g:全局搜索 m:多行搜索 元字符: \轉義字符 \w:字符,數字,下劃 ... 
- css 浮动问题 display显示 和 光标设置cursor
			<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>浮 ... 
- Mybatis-java.lang.RuntimeException: org.apache.ibatis.exceptions.PersistenceException:  ### Error building SqlSession. ### The error may exist in sqlmap/User.xml ### Cause: org.apache.ibatis.builder.B
			mappers(映射器) 使用相对于类路径的资源 如:<mapper resource="sqlmap/User.xml" /> 使用完全限定路径 如:<mapp ... 
