20200104模拟赛 问题A 图样
题目



分析:
老规矩,遇到期望要准备好随时投降。。。
大致想到了按位处理,然后分别下去搜索,再用组合数加加减减一下。。。
但是两个连通块之间连边的期望怎么算呢?
很好,投降。。。
下来看题解。。。
果然是记搜。。
首先我们设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 图样的更多相关文章
- 20200104模拟赛 问题C 上台拿衣服
题目 分析: 乍一看不就是从楼上扔鸡蛋那道题吗... 然后开始写写写... 设f [ i ] [ j ]表示 i 个记者膜 j 次可以验证多少层楼... 于是开始递推: 我们选取第 i 个记者去尝试其 ...
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- NOI模拟赛 Day1
[考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ...
- NOIP第7场模拟赛题解
NOIP模拟赛第7场题解: 题解见:http://www.cqoi.net:2012/JudgeOnline/problemset.php?page=13 题号为2221-2224. 1.car 边界 ...
- contesthunter暑假NOIP模拟赛第一场题解
contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- 小奇模拟赛9.13 by hzwer
2015年9月13日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿(explo) [题目背景] 小奇要开采一些矿物,它驾驶着一台带有钻头(初始能力值w)的飞船,按既定路线依次飞 ...
- PKUSC 模拟赛 day1 下午总结
下午到了机房之后又困又饿,还要被强行摁着看英文题,简直差评 第一题是NOIP模拟赛的原题,随便模拟就好啦 本人模拟功力太渣不小心打错了个变量,居然调了40多分钟QAQ #include<cstd ...
- [GRYZ]寒假模拟赛
写在前面 这是首次广饶一中的OIERS自编自导,自出自做(zuo)的模拟赛. 鉴于水平气压比较低,机(wei)智(suo)的WMY/XYD/HYXZC就上网FQ下海找了不少水(fei)题,经过他们优( ...
随机推荐
- python 多线程两种实现方式,Python多线程下的_strptime问题,
python 多线程两种实现方式 原创 Linux操作系统 作者:杨奇龙 时间:2014-06-08 20:24:26 44021 0 目前python 提供了几种多线程实现方式 thread,t ...
- Consul etcd ZooKeeper euerka 对比
这里就平时经常用到的服务发现的产品进行下特性的对比,首先看下结论: Feature Consul zookeeper etcd euerka 服务健康检查 服务状态,内存,硬盘等 (弱)长连接,kee ...
- Vijos1788 第K大 [模拟]
1.题意:给定N个数字,和一个值K,要求输出一组数据中第K大的数字,其中30%的测试点满足:n <= 100;60%的测试点满足:n <= 1000;100%的测试点满足:n <= ...
- 第三阶段:3.Web端产品设计:5.产品设计-视觉设计
视觉设计主要在表现层. 色彩心理产品经理可以也是应当掌握的.什么颜色的选择都是有理有据的. 信息清晰度. 比如这个图:当用户操作出问题,谷歌会给出问题同时给出解决方法. 视觉动物. 2/8分布原则.用 ...
- xshell连接不上ubuntu---could not connect to 'ip' (port 22): Connection failed.
可能是没有开启ssh server,接下来就是开启服务就好.命令如下: sudo apt-get install openssh-server 这样就OK啦
- Linux安装MySQL及基本操作(Centos)
安装: 系统:CentOS-7-x86_64-DVD-1810.iso 安装命令: wget http://repo.mysql.com/mysql-community-release-el7-5.n ...
- 0182 JavaScript执行机制:单线程,同步任务和异步任务,执行栈,消息队列,事件循环
以下代码执行的结果是什么? [结果是1 2 3 ] console.log(1); setTimeout(function () { console.log(3); }, 1000); console ...
- Java 数据结构快速入门
数据结构:栈 简介 栈(stack),又称堆栈,它是运算受限的线性表. 限制 栈(stack)的限制是仅允许在标的一端进行插入和删除操作,不允许在其他任何位置进行添加.查找.删除等操作. 采用该结构的 ...
- 使用wireshark 对flutter 框架APP进行抓包
引言 最近公司开发一个APP,由于原生人力不足,直接由前端使用flutter 开发的,而使用flutter框架开发的客户端 fiddler无法抓到包,所以我采用wireshark从路由层面抓包 fid ...
- 三、JVM之方法区
一.什么式方法区 方法区,也称非堆(Non-Heap),又是一个被线程共享的内存区域.其中主要存储加载的类字节码.class/method/field等元数据对象.static-final常量.sta ...