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)题,经过他们优( ...
随机推荐
- 深入Oracle的left join中on和where的区别详解
-- from http://blog.itpub.net/30175262/viewspace-1472060/ 今天遇到一个求某月所有天数的统计结果,如果某日的结果是0也需要显示出来,即: 日期 ...
- Oracle Net Manager 的使用方法(监听的配置方法)
一,在服务端配置oracle端口 win+R 输入netca 弹出如下窗口后 选择监听程序配置,点击下一步 二.配置端口后使用Telnet工具调试端口是否联通 在命令行输入telnet 服务器ip ...
- visio基础
右下角是一个切换文件的按钮 也可以用ctrl+tab键进行切换 页面底部左边是一个页面的增加与切换的几个按钮 这是切换页面不是切换文件 右上角这个按钮是一个功能隐藏的按钮 左上角这个按钮可以自定义快速 ...
- xcode无线调试
前言: xcode9 以上才会有无线调试这个功能,换了一个type-c口的mac,公司的新电脑,但是公司不给配转接口,到某东看了一下,type-c口同时可以转化usb和VGA的要198,官网差不多50 ...
- 关于js如果控制标签的字符长度
js名字长度限定(如限制为50个字符,超过的显示...) var new_playerName = ""; jQuery(".translate").each( ...
- 020 ceph作openstack的后端存储
一.使用ceph做glance后端 1.1 创建用于存储镜像的池 [root@serverc ~]# ceph osd pool create images 128 128 pool 'images ...
- JAVA8之 Stream 流(四)
如果说前面几章是函数式编程的方法论,那么 Stream 流就应该是 JAVA8 为我们提供的最佳实践. Stream 流的定义 Stream 是支持串行和并行操作的一系列元素.流操作会被组合到流管道中 ...
- phpqrcode生成任意尺寸的二维码
在Thinkphp中整合phpqrcode用于生成二维码,其代码如下: vendor("phpqrcode.phpqrcode"); QRcode::png('http://www ...
- 一定要你明白Java中的volatile
今天Tony来和大家聊聊Java中关键字volatile. 字节码 首先volatile int a = 3;和int a = 3;, 加不加volatile关键字,最终生成的字节码都一样的.有兴趣的 ...
- webpack 实时编译typescript与scss
webpack.config.js const path = require('path'); const CopyWebpackPlugin = require('copy-webpack-plug ...