题目

分析:

老规矩,遇到期望要准备好随时投降。。。

大致想到了按位处理,然后分别下去搜索,再用组合数加加减减一下。。。

但是两个连通块之间连边的期望怎么算呢?

很好,投降。。。

下来看题解。。。

果然是记搜。。

首先我们设F(n,m)表示n个点取 [ 0 , 2^m )的值时所有最小生成树代价之和

那么Ans=F(n,m) / 2^(n*m)

再设G(S,T,m)表示一部分点集大小为S,另一部分大小为T,点权取值在[ 0 , 2^m )之间后,所有情况最小边权值的总和

于是F(n,m)可以记搜:

F(n,m)=

sigma(i=1...n) C(n,i)(选哪些点) * (

F( i , m-1 ) * 2^( (n-i) * (m-1) )(一部分向下搜索再乘方案数) +

F( n-i , m-1 ) * 2^( i * (m-1) )(另一部分) +

G( i , n-i , m-1)(中间连边) +

2 ^ (m-1) * 2 ^ ( n * (m-1) )(必须花费的代价乘上方案数) )

然后我们来求G:

我们叒设一个函数P(S,T,m,K)表示点集S,T,取值[ 0 , 2^m )时,边权最小值大于等于K的情况数

G(S,T,m)可以巧妙地化为sigma(i=1...(2^m-1))P(S,T,m,i)

奥妙重重,可以脑补一下,跟前缀和差不多的感觉

然后P就很好求了,暴力地将S和T继续按01位分割下去,某一位全部都不分割时统计入答案

三重记搜,式子还这么难

神仙题Orz

#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<vector> #define maxn 55
#define maxm 9
#define MOD 258280327 using namespace std; inline long long getint()
{
long long num=,flag=;char c;
while((c=getchar())<''||c>'')if(c=='-')flag=-;
while(c>=''&&c<='')num=num*+c-,c=getchar();
return num*flag;
} int n,m;
long long C[maxn][maxn],F[maxn][maxm],G[maxn][maxn][maxm],P[maxn][maxn][maxm][<<maxm],pw[maxn*maxm]; inline long long ksm(long long num,long long k)
{
long long ret=;
for(;k;k>>=,num=num*num%MOD)if(k&)ret=ret*num%MOD;
return ret;
} inline long long getP(int S,int T,int M,int K)
{
if(S>T)swap(S,T);
if(!S||K<=)return pw[(S+T)*M];
if(K>=(<<M))return ;
if(~P[S][T][M][K])return P[S][T][M][K];
long long tmp=;
for(int i=;i<=S;i++)for(int j=;j<=T;j++)
if((i==&&j==T)||(i==S&&j==))tmp=(tmp+getP(S,T,M-,K-(<<(M-))))%MOD;
else tmp=(tmp+getP(i,j,M-,K)*getP(S-i,T-j,M-,K)%MOD*C[S][i]%MOD*C[T][j]%MOD)%MOD;
return P[S][T][M][K]=tmp;
} inline long long getG(int S,int T,int M)
{
if(!M)return ;
if(S>T)swap(S,T);
if(~G[S][T][M])return G[S][T][M];
long long tmp=;
for(int i=;i<(<<M);i++)
tmp=(tmp+getP(S,T,M,i))%MOD;
return G[S][T][M]=tmp;
} inline long long getF(int N,int M)
{
if(!M||N<)return ;
if(~F[N][M])return F[N][M];
long long tmp=*getF(N,M-)%MOD;
for(int i=;i<N;i++)
tmp=(tmp+C[N][i]*(getF(i,M-)*pw[(N-i)*(M-)]%MOD+getF(N-i,M-)*pw[i*(M-)]%MOD+getG(i,N-i,M-)+(<<(M-))*pw[N*(M-)]%MOD))%MOD;
return F[N][M]=tmp;
} int main()
{
n=getint(),m=getint();
pw[]=;for(int i=;i<=n*m;i++)pw[i]=pw[i-]*%MOD;
for(int i=;i<=n;i++)
{
C[i][]=C[i][i]=;
for(int j=;j<i;j++)C[i][j]=(C[i-][j-]+C[i-][j])%MOD;
}
memset(F,-,sizeof F),memset(G,-,sizeof G),memset(P,-,sizeof P);
printf("%lld\n",getF(n,m)*ksm(pw[n*m],MOD-)%MOD);
}

20200104模拟赛 问题A 图样的更多相关文章

  1. 20200104模拟赛 问题C 上台拿衣服

    题目 分析: 乍一看不就是从楼上扔鸡蛋那道题吗... 然后开始写写写... 设f [ i ] [ j ]表示 i 个记者膜 j 次可以验证多少层楼... 于是开始递推: 我们选取第 i 个记者去尝试其 ...

  2. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  3. NOI模拟赛 Day1

    [考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ...

  4. NOIP第7场模拟赛题解

    NOIP模拟赛第7场题解: 题解见:http://www.cqoi.net:2012/JudgeOnline/problemset.php?page=13 题号为2221-2224. 1.car 边界 ...

  5. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  6. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  7. 小奇模拟赛9.13 by hzwer

    2015年9月13日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿(explo) [题目背景] 小奇要开采一些矿物,它驾驶着一台带有钻头(初始能力值w)的飞船,按既定路线依次飞 ...

  8. PKUSC 模拟赛 day1 下午总结

    下午到了机房之后又困又饿,还要被强行摁着看英文题,简直差评 第一题是NOIP模拟赛的原题,随便模拟就好啦 本人模拟功力太渣不小心打错了个变量,居然调了40多分钟QAQ #include<cstd ...

  9. [GRYZ]寒假模拟赛

    写在前面 这是首次广饶一中的OIERS自编自导,自出自做(zuo)的模拟赛. 鉴于水平气压比较低,机(wei)智(suo)的WMY/XYD/HYXZC就上网FQ下海找了不少水(fei)题,经过他们优( ...

随机推荐

  1. 中文javadoc

    大量的中文注释,其实最大的目的是想生成中文的Javadoc.但是中文注释实在太不高级了,在各种编码下还会变成乱码.本着高端大气国际化的思路,还是想把它换成英文,但是又不想放弃中文的Javadoc,怎么 ...

  2. mac如何查看已连接wifi的密码

    可以通道mac自带的“钥匙串访问”功能查看.选择需要查询的wifi名称,右击选择“将密码拷贝到剪贴板”,输入管理员密码后,密码就拷贝好了. 找个地方粘贴即可看到密码

  3. Objection基本原理

    1,Objection 的简介 就是一个依赖注入框架,github地址:https://github.com/atomicobject/objection 2,Objection 原理 3,Objec ...

  4. spring boot中表单验证的使用

    一.前言 为啥子要搞这个表单验证呢?答案简单而现实,举个栗子,你辛辛苦苦的写了一个录入个人信息的功能,比如年龄这个位置,用户就没看到一下子写了个性别男,一提交,直接报错了,是不是很尴尬呢, 作为一个测 ...

  5. 20191017-6 alpha week 2/2 Scrum立会报告+燃尽图 05

    此作业要求参见https://edu.cnblogs.com/campus/nenu/2019fall/homework/9802 小组名称:“组长”组 组长:杨天宇 组员:魏新,罗杨美慧,王歆瑶,徐 ...

  6. 洛谷$1156$ 垃圾陷阱 $dp$

    \(Sol\) \(f_{i,j}\)前\(i\)个垃圾,能活到时间\(j\)的最高垃圾高度.\(t_i\)表示第\(i\)个垃圾掉落的时间,\(g_i\)表示吃垃圾\(i\)能维持的时间,\(h_i ...

  7. 三分钟学会使用Docker部署.NET Core

    大概快有一年的时间没有碰过docker了,理由很简单,基本上都是在IIS上部署,看到很多大佬都开始Devops持续化集成了,但相对来说成本会更高,但对于大型团队来说还是不错的,这不?不想被大伙甩下,哈 ...

  8. 1068 万绿丛中一点红 (20分)C语言

    对于计算机而言,颜色不过是像素点对应的一个 24 位的数值.现给定一幅分辨率为 M×N 的画,要求你找出万绿丛中的一点红,即有独一无二颜色的那个像素点,并且该点的颜色与其周围 8 个相邻像素的颜色差充 ...

  9. 1024 科学计数法 (20 分)C与Java

    科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [±][1-9].[0-9]+E[±][0-9]+,即数字的整数部分只有 1 位,小数部分至少有 1 位,该数字及其指数部 ...

  10. Java基础知识学习(一)--引用

    1.概念 如果一个变量的类型为类类型,而非基本类型,那么该变量就叫做引用:   2.对象引用 new Person(); 如上,代表创建了一个对象,但也仅仅是创建了,并没有办法去访问它.   为了访问 ...