链接:

P3232


题意:

和上次考试 T4 的简化且无修改一样,经典图上高斯消元求期望。


分析:

要求出每个点的期望出发次数 \(f_i\),每个点度数为 \(d_i\),有

\[f1=\sum\dfrac{f_v}{d_v}+1,f_u=\sum\dfrac{f_v}{d_v},f_n=0
\]

高斯消元即可。那么一条边 \((u,v)\) 的贡献就是 \((\dfrac{f_u}{d_u}+\dfrac{f_v}{d_v})*i\)。

考虑算出每条边的 \((\dfrac{f_u}{d_u}+\dfrac{f_v}{d_v})\),记为 \(w_i\),然后有一个容易猜的贪心结论是将 \(w_i\) 从小到大排序,然后逐个乘上 \(m-i+1\),也就是正序乘倒序时,答案最小。


算法:

利用$$f1=\sum\dfrac{f_v}{d_v}+1,f_u=\sum\dfrac{f_v}{d_v},f_n=0$$,高斯消元算出每个点的期望出发次数,然后转化为边的期望经过次数,最后再排序。时间复杂度 \(O(n^3+m\log m)\)


代码:
#include<bits/stdc++.h>
using namespace std;
#define int long long
#define in read()
inline int read(){
int p=0,f=1;
char c=getchar();
while(c>'9'||c<'0'){if(c=='-')f=-1;c=getchar();}
while(c>='0'&&c<='9'){p=p*10+c-'0';c=getchar();}
return p*f;
}
const int N=505;
const int M=125005;
int n;
struct matrix{
int x,y;
double a[N][N];
}A,B;
matrix operator*(const matrix &a,const matrix &b){
matrix c;
for(int i=1;i<=a.x;i++)
for(int j=1;j<=b.y;j++)
c.a[i][j]=0;
c.x=a.x,c.y=b.y;
for(int i=1;i<=a.x;i++)
for(int j=1;j<=b.y;j++)
for(int k=1;k<=a.y;k++)
c.a[i][j]+=a.a[i][k]*b.a[k][j];
return c;
}
matrix matinv(matrix &a){
matrix c;c.x=n,c.y=n;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
c.a[i][j]=(i==j);
for(int i=1;i<=n;i++){
int now=i;
for(int j=i+1;j<=n;j++)
if(fabs(a.a[j][i])>fabs(a.a[now][i]))now=j;
swap(a.a[i],a.a[now]);swap(c.a[i],c.a[now]);
double div=a.a[i][i];
for(int j=1;j<=n;j++)
a.a[i][j]/=div,c.a[i][j]/=div;
for(int j=1;j<=n;j++){
if(j==i)continue;
div=a.a[j][i];
for(int k=i;k<=n;k++)
a.a[j][k]-=div*a.a[i][k];
for(int k=1;k<=n;k++)
c.a[j][k]-=div*c.a[i][k];
}
}
return c;
}
int m,q;
int d[N];
int u[M],v[M];
double as[M];
signed main(){
n=in,m=in;
for(int i=1;i<=m;i++)
u[i]=in,v[i]=in,
d[u[i]]++,d[v[i]]++;
A.x=n,A.y=n;
for(int i=1;i<=m;i++)
A.a[u[i]][v[i]]=-1.0/d[v[i]],
A.a[v[i]][u[i]]=-1.0/d[u[i]];
for(int i=1;i<=n;i++)
A.a[n][i]=A.a[i][n]=0.0,A.a[i][i]=1.0;
int tmp=1;
B.a[1][1]=1.0;
B.x=n,B.y=tmp;
A=matinv(A);
B=A*B;
double ans=0;
for(int i=1;i<=m;i++)
as[i]=B.a[u[i]][1]/d[u[i]]+B.a[v[i]][1]/d[v[i]];
sort(as+1,as+1+m);
for(int i=1;i<=m;i++)
ans+=i*as[m-i+1];
printf("%.3lf",ans);
return 0;
}

题外话:

用上次的代码改了改就过了

洛谷 P3232 [HNOI2013]游走的更多相关文章

  1. 洛谷P3232[HNOI2013]游走

    有一个无向简单连通图,顶点从 \(1\) 编号到 \(n\),边从 \(1\) 编号到 \(m\) 小Z在该图上进行随机游走,初始时小Z在\(1\)号顶点,每一步小Z以相等的概率随机选 择当前顶点的某 ...

  2. [bzoj3143] [洛谷P3232] [HNOI2013] 游走

    Description 一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当前顶点的某条边,沿着这条边走到下一个顶点, ...

  3. 洛谷P3232 [HNOI2013]游走(高斯消元+期望)

    传送门 所以说我讨厌数学……期望不会高斯消元也不会……好不容易抄好了高斯消元板子被精度卡成琪露诺了…… 首先,我们先算出走每一条边的期望次数,那么为了最小化期望,就让大的期望次数乘上小编号 边的期望次 ...

  4. 题解 P3232 [HNOI2013]游走

    洛谷P3232[NOI2013]游走 题目描述 给定一个 n 个点 m 条边的无向连通图,顶点从 1 编号到 n,边从 1 编号到 m. 小 Z 在该图上进行随机游走,初始时小 Z 在 1 号顶点,每 ...

  5. P3232 [HNOI2013]游走 解题报告

    P3232 [HNOI2013]游走 题目描述 一个无向连通图,顶点从\(1\)编号到\(N\),边从\(1\)编号到\(M\). 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概 ...

  6. P3232 [HNOI2013]游走——无向连通图&&高斯消元

    题意 一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当前顶点的某条边,沿着这条边走到下一个顶点,获得等于这条边的编 ...

  7. P3232 [HNOI2013]游走

    吐槽 傻了傻了,对着题解改了好长时间最后发现是自己忘了调用高斯消元了... 思路 期望题,分配编号,显然编号大的分给贡献次数小的,所以需要知道每个边被经过次数的期望 然后边被经过的次数的期望就是连接的 ...

  8. BZOJ 3143 Luogu P3232 [HNOI2013]游走 (DP、高斯消元)

    题目链接: (bzoj) https://www.lydsy.com/JudgeOnline/problem.php?id=3143 (luogu) https://www.luogu.org/pro ...

  9. bzoj 3143: [Hnoi2013]游走 高斯消元

    3143: [Hnoi2013]游走 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1026  Solved: 448[Submit][Status] ...

随机推荐

  1. 日期SQL 脚本

    一个月第一天的 SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)本周的星期一     SELECT DATEADD(wk, DATEDIFF(wk,0,g ...

  2. 机器学习——集成学习(Bagging、Boosting、Stacking)

    1 前言 集成学习的思想是将若干个学习器(分类器&回归器)组合之后产生一个新学习器.弱分类器(weak learner)指那些分类准确率只稍微好于随机猜测的分类器(errorrate < ...

  3. 【原创】【长期更新】【未完待续】自制vector类型

    继<自制string类型>以来的第二篇自制类型的文章.马上要开学了,时间也不多了,争取在今年写完吧. 目录 一,vector类型简单介绍 1.简介 1.1.STL 1.2.vector 2 ...

  4. scrapy各种持久化存储的奇淫技巧

    理论 磁盘文件: 基于终端指令 1)保证parse方法返回一个可迭代类型的对象(存储解析到的页面内容) 2)使用终端指令完成数据存储到指定磁盘文件中的操作,如:scrapy crawl 爬虫文件名称 ...

  5. 查看Win10商店应用更新日期

    查看Win10商店应用更新日期 需要用到一个工具--WP Snitch,网址 https://wpsnitch.appspot.com/ 打开网址后他会给出一个示例,比如给出的是 https://ww ...

  6. 记一次 .NET 某上市工业智造 CPU+内存+挂死 三高分析

    一:背景 1. 讲故事 上个月有位朋友加wx告知他的程序有挂死现象,询问如何进一步分析,截图如下: 看这位朋友还是有一定的分析基础,可能玩的少,缺乏一定的分析经验,当我简单分析之后,我发现这个dump ...

  7. Linux系列(1) - 使用Hyper-V安装Linux系统

    前言 使用工具:Hyper-V,补充:hyper-v是一项技术,而vmware是一款软件.具体区别自行百度 LINUX版本:CentOS-8.4.2105-x86_64-dvd1.iso Window ...

  8. P7276-送给好友的礼物【dp】

    正题 题目链接:https://www.luogu.com.cn/problem/P7276?contestId=39577 题目大意 \(n\)个点的一棵树,\(k\)个关键点,两个人从根出发分别走 ...

  9. 关于docker复现vulhub环境的搭建

    原本想用docker复现一下vul的漏洞. 装docker过程中遇到了很多问题, 昨天熬夜到凌晨三点都没弄完. 中午又找了找原因,终于全部解决了, 小结一下. 0x01 镜像 去官方下载了centos ...

  10. 数据库建表权限 CREATE command denied to user for table

    今天在表中用Navicat连接服务器上的mysql账号进行建表,报了个这样类似的错, CREATE command denied to user for table 是数据库权限设置的问题,所以无法进 ...