【UOJ#75】【UR #6】智商锁(矩阵树定理,随机)

题面

UOJ

题解

这种题我哪里做得来啊[惊恐],,,

题解做法:随机\(1000\)个点数为\(12\)的无向图,矩阵树定理算出它的生成树个数,然后找到四张图不拼接直接放在一起,也就是找到四个图,假设其生成树个数是\(f(G)\),那么就找到\(f(G_1)f(G_2)f(G_3)f(G_4)\equiv k\),然后预处理两两的乘积,丢到哈希表/\(\text{map}\)里,枚举另外一半直接查。。。

无向图的生成方式是每条边出现的概率是\(0.8\)。然后\(rand\)的时候确保图连通。

还需要再特判一下\(k=0\)的情况。

然后概率的证明直接蒯题解吧。。。

首先我们随机无向图的方法是每一条边生成的概率都是\(0.8\),而\(12\)个点的完全图的生成树个数是\(12^{10}\),这是远大于模数的,所以我们可以近似地把\(f_i\)看做均匀分布的随机数(这个和我们平时写的哈希表的思想类似)。接下来我们把这\(1000\)个随机数的集合四次方再模上模数,这样我们就得到了\(10^{12}\)个数,和刚才同理,我们也可以把这\(10^{12}\)个数给近似地看成均匀分布的随机数。

接下来我们要求的是\(10^{12}\)个小于等于\(10^9\)的随机数完全覆盖\(0\)到\(10^9\)之间所有数的概率是多少。首先一个数被覆盖的概率是\(1-(1-\frac{1}{10^9})^{10^{12}} \approx 1-\mathrm{e}^{-10^3}\),我们可以近似地认为所有数都被覆盖的概率是\((1-\mathrm{e}^{-10^3})^{10^9}\),实际上这个数是非常接近\(1\)的(因为\(e^{10^3}\)比\(10^9\)大到哪里去都不知道了)

打不过打不过。

#include<iostream>
#include<cstdio>
#include<map>
using namespace std;
#define MOD 998244353
inline int read()
{
int x=0;bool t=false;char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=true,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return t?-x:x;
}
int fpow(int a,int b){int s=1;while(b){if(b&1)s=1ll*s*a%MOD;a=1ll*a*a%MOD;b>>=1;}return s;}
struct Graph
{
int g[15][15],a[15][15],T,edge;
void Calc()
{
T=1;
for(int i=2;i<=12;++i)
{
for(int j=i+1;j<=12;++j)
while(a[j][i])
{
int t=a[i][i]/a[j][i];
for(int k=i;k<=12;++k)a[i][k]=(a[i][k]+MOD-1ll*a[j][k]*t%MOD)%MOD;
for(int k=i;k<=12;++k)swap(a[i][k],a[j][k]);
T=MOD-T;
}
}
for(int i=2;i<=12;++i)T=1ll*T*a[i][i]%MOD;T=(T+MOD)%MOD;
}
void Add(int u,int v){++edge;g[u][v]=g[v][u]=1;a[u][v]--;a[v][u]--;a[u][u]++;a[v][v]++;}
void Rand()
{
for(int i=2;i<=12;++i)Add(rand()%(i-1)+1,i);
for(int i=1;i<=12;++i)
for(int j=i+1;j<=12;++j)
if(!g[i][j]&&rand()%10<8)
Add(i,j);
Calc();
}
void Output(int N)
{
for(int i=1;i<=12;++i)
for(int j=i+1;j<=12;++j)
if(g[i][j])printf("%d %d\n",N+i,N+j);
}
}G[1010];
pair<int,int> a[1010101];
int S[1010101],tot;
map<int,pair<int,int> >M;
void Output(int a,int b,int c,int d)
{
printf("48 %d\n",G[a].edge+G[b].edge+G[c].edge+G[d].edge+3);
G[a].Output(0);G[b].Output(12);G[c].Output(24);G[d].Output(36);
printf("1 13\n13 25\n25 37\n");
}
int main()
{
for(int i=1;i<=1000;++i)G[i].Rand();
for(int i=1;i<=1000;++i)
for(int j=i;j<=1000;++j)
++tot,M[S[tot]=1ll*G[i].T*G[j].T%MOD]=a[tot]=make_pair(i,j);
int T=read();
while(T--)
{
int K=read();if(!K){puts("2 0");continue;}
for(int i=1;i<=tot;++i)
{
int v=1ll*K*fpow(S[i],MOD-2)%MOD;
if(M.find(v)!=M.end())
{
Output(a[i].first,a[i].second,M[v].first,M[v].second);
break;
}
}
}
return 0;
}

【UOJ#75】【UR #6】智商锁(矩阵树定理,随机)的更多相关文章

  1. UOJ 75 - 【UR #6】智商锁(矩阵树定理+随机+meet-in-the-middle)

    题面传送门 一道很神的矩阵树定理+乱搞的题 %%%%%%%%%%%%%%% vfk yyds u1s1 这种题目我是根本想不出来/kk,大概也就 jgh 这样的随机化带师才能想到出来吧 首先看到生成树 ...

  2. 矩阵树定理&BEST定理学习笔记

    终于学到这个了,本来准备省选前学来着的? 前置知识:矩阵行列式 矩阵树定理 矩阵树定理说的大概就是这样一件事:对于一张无向图 \(G\),我们记 \(D\) 为其度数矩阵,满足 \(D_{i,i}=\ ...

  3. [spoj104][Highways] (生成树计数+矩阵树定理+高斯消元)

    In some countries building highways takes a lot of time... Maybe that's because there are many possi ...

  4. BZOJ 4766: 文艺计算姬 [矩阵树定理 快速乘]

    传送门 题意: 给定一个一边点数为n,另一边点数为m,共有n*m条边的带标号完全二分图$K_{n,m}$ 求生成树个数 1 <= n,m,p <= 10^18 显然不能暴力上矩阵树定理 看 ...

  5. bzoj 4596 [Shoi2016]黑暗前的幻想乡 矩阵树定理+容斥

    4596: [Shoi2016]黑暗前的幻想乡 Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 559  Solved: 325[Submit][Sta ...

  6. 【LOJ#6072】苹果树(矩阵树定理,折半搜索,容斥)

    [LOJ#6072]苹果树(矩阵树定理,折半搜索,容斥) 题面 LOJ 题解 emmmm,这题似乎猫讲过一次... 显然先\(meet-in-the-middle\)搜索一下对于每个有用的苹果数量,满 ...

  7. 2019.01.02 bzoj2467: [中山市选2010]生成树(矩阵树定理)

    传送门 矩阵树定理模板题. 题意简述:自己看题面吧太简单懒得写了 直接构建出这4n4n4n个点然后按照题面连边之后跑矩阵树即可. 代码: #include<bits/stdc++.h> # ...

  8. [CF917D]Stranger Trees[矩阵树定理+解线性方程组]

    题意 给你 \(n\) 个点的无向完全图,指定一棵树 \(S\),问有多少棵生成树和这棵树的公共边数量为 \(k\in[0,n-1]\) \(n\leq 100\) 分析 考虑矩阵树定理,把对应的树边 ...

  9. 【bzoj4596】[Shoi2016]黑暗前的幻想乡 容斥原理+矩阵树定理

    题目描述 给出 $n$ 个点和 $n-1$ 种颜色,每种颜色有若干条边.求这张图多少棵每种颜色的边都出现过的生成树,答案对 $10^9+7$ 取模. 输入 第一行包含一个正整数 N(N<=17) ...

随机推荐

  1. 近日LeetCode算法(记录)

    近日LeetCode算法 前言:最近刷了好多leetcode算法题,大家知道,程序=数据结构+算法,由此可见,算法真的是很重要的呢.闲话少谈,切入正题,来看看小编觉得有点意思的5题算法题吧... 1. ...

  2. 【LeetCode】2. 两数相加

    题目 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字.   如果,我们将这两个数相加起来,则会返回一个新的链表来表 ...

  3. 终于我还是没忍住,用Python爬了一波女神

    你学爬虫,最终不还是为了爬妹子 啥也不说,开始福利赠送~ 女神大会 不是知道有多少人知道“懂球帝”这个 APP(网站),又有多少人关注过它的一个栏目“女神大会”,在这里,没有足球,只有女神哦. 画风是 ...

  4. C++ this指针的理解和作用

    01 C++ 程序到 C 程序的翻译 要想理解 C++ 的 this 指针,我们先把下面的 C++ 代码转换成 C 的代码 class Car { public: int m_price; // 成员 ...

  5. Wireshark使用教程:不同报文颜色的含义

    - 设置 色彩规则有两个入口,一个在报文上方的工具栏内,如图: 那个鲜艳的图标就是色彩规则的入口. 另一个是view-->coloring rules菜单. 点击进去即可看见所有的色彩规则的设置 ...

  6. [20190522]DISABLE TABLE LOCK.txt

    [20190522]DISABLE TABLE LOCK.txt --//如果禁止table lock时,一些ddl操作会被禁止.但是我有点吃惊的是增加字段不受限制.--//通过测试说明问题. 1.环 ...

  7. TypeScript 学习笔记(一)

    TypeScript: 1.是 JavaScript 的一个超集,支持 ES6 标准 2.由微软开发的自由和开源的编程语言 3.设计目标是开发大型应用,它可编译成纯 JavaScript,编译出来的 ...

  8. SQL Server 完整备份遇到的一个不常见的错误

    1. 错误详情 有一次在手动执行数据库完整备份时遇到如下错误: 执行多次都是这个错误信息. 提示无法生成检查点,原因可能是由于系统资源(如磁盘或内存空间)不足或者有时是由于数据库损坏而造成的. 我们检 ...

  9. BayaiM__linux双网卡绑定文档

    BayaiM__linux双网卡绑定文档 开门贱山:以下内容纯属原创,如有雷同,爱咋咋滴吧~~!!—————————————————————————————————————————— 1,备份网卡信息 ...

  10. 错误:shell 打开出现一大堆 错误 declare -x 之类的消息

    像图中这种情况:这是什么情况呢? 原因:可能是你最近修改了.bashrc 或者 bash_profile 之类的文件.其中export 命令,要求export 命令写在单独的一行上: 就像下面这样,如 ...