BZOJ3143: [Hnoi2013]游走(期望DP 高斯消元)
Time Limit: 10 Sec  Memory Limit: 128 MB
Submit: 3597  Solved: 1618
[Submit][Status][Discuss]
Description
一个无向连通图,顶点从1编号到N,边从1编号到M。 
小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当前顶点的某条边,沿着这条边走到下一个顶点,获得等于这条边的编号的分数。当小Z 到达N号顶点时游走结束,总分为所有获得的分数之和。 
现在,请你对这M条边进行编号,使得小Z获得的总分的期望值最小。
Input
第一行是正整数N和M,分别表示该图的顶点数 和边数,接下来M行每行是整数u,v(1≤u,v≤N),表示顶点u与顶点v之间存在一条边。 输入保证30%的数据满足N≤10,100%的数据满足2≤N≤500且是一个无向简单连通图。
Output
仅包含一个实数,表示最小的期望值,保留3位小数。
Sample Input
2 3
1 2
1 3
Sample Output
HINT
Source
#include<cstdio>
#include<cstring>
#include<algorithm>
#define getchar() (p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<23,stdin),p1==p2)?EOF:*p1++)
using namespace std;
const int MAXN=1e6+;
const double eps=1e-;
char buf[<<],*p1=buf,*p2=buf;
inline int read()
{
char c=getchar();int x=,f=;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
}
int N,M;
struct node
{
int u,v,nxt;
}edge[MAXN];
int head[MAXN],num=;
inline void AddEdge(int x,int y)
{
edge[num].u=x;
edge[num].v=y;
edge[num].nxt=head[x];
head[x]=num++;
}
double f[][],ans[MAXN],E[MAXN],inder[MAXN];
int S[MAXN],T[MAXN];
int dcmp(double x)
{
if(x<eps&&x>-eps) return ;
else return x<?-:;
}
void Gauss()
{ for(int i=;i<N;i++)
{
int mx=i;
for(int j=i+;j<N;j++)
if( dcmp(f[j][i]-f[mx][i])> ) mx=j;
if(mx!=i) swap(f[i],f[mx]);
for(int j=i+;j<N;j++)
{
double tmp=f[j][i]/f[i][i];
for(int k=i;k<=N;k++)
f[j][k]-=(double)tmp*f[i][k];
}
}
for(int i=N-;i>=;i--)
{
for(int j=i+;j<N;j++)
f[i][N]-=ans[j]*f[i][j];
ans[i]=f[i][N]/f[i][i];
}
}
int main()
{
#ifdef WIN32
freopen("a.in","r",stdin);
#else
#endif
memset(head,-,sizeof(head));
N=read(),M=read();
for(int i=;i<=M;i++)
{
int x=read(),y=read();
AddEdge(x,y);AddEdge(y,x);
inder[x]++;inder[y]++;
S[i]=x;T[i]=y;
}
f[][N]=;
for(int i=;i<N;i++) f[i][i]=;
for(int i=;i<N;i++)
for(int j=head[i];j!=-;j=edge[j].nxt)
if(edge[j].v!=N)
f[i][edge[j].v]=(double)-1.00/inder[edge[j].v];
Gauss();
for(int i=;i<=M;i++)
E[i]=ans[S[i]]/inder[S[i]]+ans[T[i]]/inder[T[i]];
sort(E+,E+M+);
double out=;
for(int i=;i<=M;i++)
out+=E[i]*(M-i+);
printf("%.3lf",out);
return ;
}
BZOJ3143: [Hnoi2013]游走(期望DP 高斯消元)的更多相关文章
- 【BZOJ3143】[Hnoi2013]游走 期望DP+高斯消元
		
[BZOJ3143][Hnoi2013]游走 Description 一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 ...
 - bzoj 3143 [Hnoi2013]游走 期望dp+高斯消元
		
[Hnoi2013]游走 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3394 Solved: 1493[Submit][Status][Disc ...
 - 2018.09.23 bzoj3143: [Hnoi2013]游走(dp+高斯消元)
		
传送门 显然只需要求出所有边被经过的期望次数,然后贪心把边权小的边定城大的编号. 所以如何求出所有边被经过的期望次数? 显然这只跟边连接的两个点有关. 于是我们只需要求出两个点被经过的期望次数. 对于 ...
 - bzoj3143 游走    期望dp+高斯消元
		
题目传送门 题意: 一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当前顶点的某条边,沿着这条边走到下一个顶点,获得 ...
 - bzoj3143: [Hnoi2013]游走(贪心+高斯消元)
		
考虑让总期望最小,那么就是期望经过次数越多的边贪心地给它越小的编号. 怎么求每条边的期望经过次数呢?边不大好算,我们考虑计算每个点的期望经过次数f[x],那么一条边的期望经过次数就是f[x]/d[x] ...
 - BZOJ 3143: [Hnoi2013]游走 [概率DP 高斯消元]
		
一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当前顶点的某条边,沿着这条边走到下一个顶点,获得等于这条边的编号的分 ...
 - 【洛谷3232】[HNOI2013] 游走(贪心+高斯消元)
		
点此看题面 大致题意: 一个无向连通图,小\(Z\)从\(1\)号顶点出发,每次随机选择某条边走到下一个顶点,并将\(ans\)加上这条边的编号,走到\(N\)号顶点时结束.请你对边进行编号,使总分期 ...
 - BZOJ_3143_[Hnoi2013]游走_期望DP+高斯消元
		
BZOJ_3143_[Hnoi2013]游走_期望DP+高斯消元 题意: 一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机 ...
 - [BZOJ3143][HNOI2013]游走(期望+高斯消元)
		
3143: [Hnoi2013]游走 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3576 Solved: 1608[Submit][Status ...
 
随机推荐
- cocos ios Label组件问题
			
软件:cocos creator v1.9.0 开发的过程中,一直在web上预览,Label组件显示一直没问题.在打包到ios上时,出现问题了: Label组件: 当我们缩小字体,发现没问题了,当我们 ...
 - BZOJ 1106: [POI2007]立方体大作战tet 树状数组 + 贪心
			
Description 一个叫做立方体大作战的游戏风靡整个Byteotia.这个游戏的规则是相当复杂的,所以我们只介绍他的简单规 则:给定玩家一个有2n个元素的栈,元素一个叠一个地放置.这些元素拥有n ...
 - Lua的五种变量类型、局部变量、全局变量、lua运算符、流程控制if语句_学习笔记02
			
Lua的五种变量类型.局部变量.全局变量 .lua运算符 .流程控制if语句 Lua代码的注释方式: --当行注释 --[[ 多行注释 ]]-- Lua的5种变量类型: 1.null 表示 ...
 - 01010_Eclipse中项目的jar包导入与导出
			
1.jar包 jar包是一个可以包含许多.class文件的压缩文件.我们可以将一个jar包加入到项目的依赖中,从而该项目可以使用该jar下的所有类:也可以把项目中所有的类打包到指定的jar包,提供给其 ...
 - 【Codeforces 996B】World Cup
			
[链接] 我是链接,点我呀:) [题意] [题解] 你可以找出来a[i]里面的最小值mi,显然是这个数字最可能先变成0,但还不确定. 然后用mi/n得到你最少需要走多少圈才能让那个mi变成" ...
 - Tomcat日志配置远程Syslog采集
			
http://blog.csdn.net/leizi191110211/article/details/51593748
 - javascript--闭包与this
			
理解javascript中的闭包与this http://www.ruanyifeng.com/blog/2009/08/learning_javascript_closures.html http: ...
 - Python学习笔记13:标准库之子进程(subprocess包)
			
ubprocess包主要功能是运行外部的命令和程序.从这个意义上来说,subprocess的功能与shell类似. subprocess以及经常使用的封装函数 当我们执行python的时候,我们都是在 ...
 - 125条常见的java面试、笔试题大汇总
			
1.抽象: 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面.抽象并不打算了解所有问题,而仅仅是选择当中的一部分,临时不用部分细节.抽象包含两个方面,一是过程抽象. ...
 - iOS GCD使用指南
			
Grand Central Dispatch(GCD)是异步运行任务的技术之中的一个. 一般将应用程序中记述的线程管理用的代码在系统级中实现.开发人员仅仅须要定义想运行的任务并追加到适当的Dispat ...