【BZOJ3143】【HNOI2013】游走 高斯消元
题目传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=3143
我们令$P_i$表示从第i号点出发的期望次数。则$P_n$显然为$0$。
对于$P_2~P_{n-1}$,则有$P_i= \sum \frac{P_j} {d_j}$,其中节点j与节点i有边相连,$d_j$表示节点j的度数。
对于$P_1$,则有$P_i=1+ \sum \frac{P_j} {d_j}$。
不难发现其实就是一个$n$元一次方程组,我们可以通过高斯消元求出每一个$P_i$。
对于一条边$(x,y)$,经过这条边的期望次数为$ \frac {P_x} {d_x} + \frac {P_y} {d_y}$,我们设此值为$p_i$ 。
我们把期望经过次数从大到小排序,则答案为$\sum_{i=1}^{n} p_i \times i$。
然后就做完了。
AC代码如下:
- #include<bits/stdc++.h>
- #define M 505
- using namespace std;
- int a[M][M]={},n,m;
- double f[M][M]={},p[M]={},du[M]={};
- void solve(){
- for(int i=;i<=n;i++){
- for(int j=i+;j<=n;j++){
- double x=f[j][i]/f[i][i];
- for(int k=i;k<=n+;k++)
- f[j][k]-=x*f[i][k];
- }
- }
- for(int i=n;i;i--){
- for(int j=i+;j<=n;j++)
- f[i][n+]-=f[i][j]*p[j];
- p[i]=f[i][n+]/f[i][i];
- }
- }
- int X[M*M]={},Y[M*M]={}; double hh[M*M]={};
- int main(){
- scanf("%d%d",&n,&m);
- for(int i=;i<=m;i++){
- int x,y; scanf("%d%d",&x,&y);
- a[x][y]=a[y][x]=;
- du[x]++; du[y]++;
- X[i]=x; Y[i]=y;
- }
- f[][n+]=-; f[n][n]=;
- for(int i=;i<n;i++){
- f[i][i]=-;
- for(int j=;j<=n;j++) if(a[i][j])
- f[i][j]=/du[j];
- }
- solve();
- for(int i=;i<=m;i++)
- hh[i]=p[X[i]]/du[X[i]]+p[Y[i]]/du[Y[i]];
- sort(hh+,hh+m+);
- double ans=;
- for(int i=;i<=m;i++)
- ans+=hh[i]*(m-i+);
- printf("%.3lf\n",ans);
- }
【BZOJ3143】【HNOI2013】游走 高斯消元的更多相关文章
- BZOJ3143:[HNOI2013]游走(高斯消元)
Description 一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当前顶点的某条边,沿着这条边走到下一个顶点, ...
- 【BZOJ-3143】游走 高斯消元 + 概率期望
3143: [Hnoi2013]游走 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2264 Solved: 987[Submit][Status] ...
- bzoj 3143: [Hnoi2013]游走 高斯消元
3143: [Hnoi2013]游走 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1026 Solved: 448[Submit][Status] ...
- BZOJ 3143 HNOI2013 游走 高斯消元 期望
这道题是我第一次使用高斯消元解决期望类的问题,首发A了,感觉爽爽的.... 不过笔者在做完后发现了一些问题,在原文的后面进行了说明. 中文题目,就不翻大意了,直接给原题: 一个无向连通图,顶点从1编号 ...
- Luogu3232 HNOI2013 游走 高斯消元、期望、贪心
传送门 这种无向图上从一个点乱走到另一个点的期望题目好几道与高斯消元有关 首先一个显然的贪心:期望经过次数越多,分配到的权值就要越小. 设$du_i$表示$i$的度,$f_i$表示点$i$的期望经过次 ...
- [HNOI2013][BZOJ3143] 游走 - 高斯消元
题目描述 一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当前顶点的某条边,沿着这条边走到下一个顶点,获得等于这条边 ...
- 【xsy1201】 随机游走 高斯消元
题目大意:你有一个$n*m$的网格(有边界),你从$(1,1)$开始随机游走,求走到$(n,m)$的期望步数. 数据范围:$n≤10$,$m≤1000$. 我们令 $f[i][j]$表示从$(1,1) ...
- [BZOJ3143][HNOI2013]游走(期望+高斯消元)
3143: [Hnoi2013]游走 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3576 Solved: 1608[Submit][Status ...
- BZOJ3143 [Hnoi2013]游走 【高斯消元】
题目 一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当前顶点的某条边,沿着这条边走到下一个顶点,获得等于这条边的编 ...
随机推荐
- display:grid
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- android触控,先了解MotionEvent(一)
http://my.oschina.net/banxi/blog/56421 这是我个人的看法,要学好android触控,了解MotionEvent是必要,对所用的MotionEvent常用的API要 ...
- hdu-1142(记忆化搜索+dij)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1142 思路:1.不是求最短路径,而是求如果两个点A,B直接相连,且A到终点的距离大于B到终点的距离,求 ...
- 一个简单的Linux后门程序的实现
该程序实质是一个简单的socket编程,在受害方上运行攻击代码(后门进程),通过socket打开一个预设端口,并监听,等待攻击方的链接.一旦攻击方通过网络链接工具试图链接该socket,那么后门进程立 ...
- SPSS—回归—曲线估计方程案例解析
上一节介绍了线性回归,虽然线性回归能够满足大部分的数据分析的要求,但是,线性回归并不是对所有的问题都适用, 因为有时候自变量和因变量是通过一个已知或未知的非线性函数关系相联系的,如果通过函数转换,将关 ...
- SqlCommand和SqlDataAdapter的区别
SqlDataAdapter对象 一.特点介绍1.表示用于填充 DataSet 和更新 SQL Server 数据库的一组数据命令和一个数据库连接.2.在SqlDataAdapter和DataSet之 ...
- The remote end hung up unexpectedly
fatal: The remote end hung up unexpectedly 上传一份代码的时候,出现了这个错误,然后就没有成功上传. 背景操作 主要是进行svn转换到git时候出错的,转换的 ...
- delphi 使用oauth的控件
unit OAuth; interface uses Classes, SysUtils, IdURI, Windows; type EOAuthException = class(Exception ...
- centos php Zookeeper kafka扩展安装
如题,系统架构升级引入消息机制,php 安装还是挺麻烦的,网上各种文章有的东拼西凑这里记录下来做个备忘,有需要的同学可以自行参考安装亲测可行 1 zookeeper扩展安装 1.安装zookeeper ...
- Apache Geode with Spark
在一些特定场景,例如streamingRDD需要和历史数据进行join从而获得一些profile信息,此时形成较小的新数据RDD和很大的历史RDD的join. Spark中直接join实际上效率不高: ...