【BZOJ】3036: 绿豆蛙的归宿
【题意】给定DAG带边权连通图,保证所有点都能到达终点n,每个点等概率沿边走,求起点1到终点n的期望长度。n<=10^5。
【算法】期望DP
【题解】f[i]表示到终点n的期望长度。
f[n]=0
f[i]=(f[j]+e[i].w)/k[i],i-->j,k[i]是i的出度。
因为是点x等概率出发,所以一定要从x算,不能倒着来。
原理:【专题】概率和期望
考虑到深搜的爆栈风险,写了拓扑排序+期望DP
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
const int maxn=;
int first[maxn],n,m,in[maxn],a[maxn],tot=,k[maxn],cnt=;//////////////////////
double f[maxn];
queue<int>q;
struct edge{int v,w,from;}e[maxn*];
void insert(int u,int v,int w){tot++;e[tot].v=v;e[tot].w=w;e[tot].from=first[u];first[u]=tot;in[v]++;k[u]++;}
int main(){
scanf("%d%d",&n,&m);
int u,v,w;
for(int i=;i<=m;i++){
scanf("%d%d%d",&u,&v,&w);
insert(u,v,w);
}
for(int i=;i<=n;i++)if(!in[i])q.push(i);
while(!q.empty()){
a[++cnt]=q.front();q.pop();
for(int i=first[a[cnt]];i;i=e[i].from){
in[e[i].v]--;
if(!in[e[i].v])q.push(e[i].v);
}
}
for(int j=n;j>=;j--){
int x=a[j];
for(int i=first[x];i;i=e[i].from){
f[x]+=f[e[i].v]+e[i].w;
}
if(k[x])f[x]/=k[x];
}
printf("%.2lf",f[]);
return ;
}
有边表的tot时,一定要注意不要用变量tot。
【BZOJ】3036: 绿豆蛙的归宿的更多相关文章
- BZOJ 3036: 绿豆蛙的归宿( 期望dp )
		
从终点往起点倒推 . 在一个图 考虑点 u , 出度为 s : s = 0 , d[ u ] = 0 ; s ≠ 0 , 则 d( u ) = ( ∑ d( v ) ) / s ( ( u , v ) ...
 - Bzoj 3036: 绿豆蛙的归宿(期望)
		
3036: 绿豆蛙的归宿 Time Limit: 2 Sec Memory Limit: 128 MB Description 随着新版百度空间的下线,Blog宠物绿豆蛙完成了它的使命,去寻找它新的归 ...
 - BZOJ 3036: 绿豆蛙的归宿 期望 + 拓扑排序
		
随着新版百度空间的下线,Blog宠物绿豆蛙完成了它的使命,去寻找它新的归宿.给出一个有向无环的连通图,起点为1终点为N,每条边都有一个长度.绿豆蛙从起点出发,走向终点. 到达每一个顶点时,如果有K条离 ...
 - BZOJ 3036 绿豆蛙的归宿
		
期望dp.类似记忆化搜索的方法实现. #include<iostream> #include<cstdio> #include<cstring> #include& ...
 - 【BZOJ 3036】 3036: 绿豆蛙的归宿 (概率DP)
		
3036: 绿豆蛙的归宿 Time Limit: 2 Sec Memory Limit: 128 MBSubmit: 491 Solved: 354 Description 随着新版百度空间的下线 ...
 - 3036: 绿豆蛙的归宿 - BZOJ
		
Description 随着新版百度空间的下线,Blog宠物绿豆蛙完成了它的使命,去寻找它新的归宿. 给出一个有向无环的连通图,起点为1终点为N,每条边都有一个长度.绿豆蛙从起点出发,走向终点.到达每 ...
 - BZOJ3036: 绿豆蛙的归宿&Wikioi2488:绿豆蛙的归宿
		
3036: 绿豆蛙的归宿 Time Limit: 2 Sec Memory Limit: 128 MBSubmit: 108 Solved: 73[Submit][Status] Descript ...
 - 【BZOJ3036】绿豆蛙的归宿 拓补排序+概率
		
[BZOJ3036]绿豆蛙的归宿 Description 随着新版百度空间的下线,Blog宠物绿豆蛙完成了它的使命,去寻找它新的归宿. 给出一个有向无环的连通图,起点为1终点为N,每条边都有一个长度. ...
 - BZOJ3036绿豆蛙的归宿
		
BZOJ3036绿豆蛙的归宿 锲下陟凝 褰宓万 郝瓦痕膳 叶诙摞 А知π剧 椐猊∫距 屠缲佗 ゲ蕖揪 俜欧彖鹤 磲砩ほ #琛扶 觅电闸ス 捆鳢げ 浜窠 魂睨"烁 蕞滗浼 洒ヂ跪 ...
 
随机推荐
- 配置ip,使你的虚拟机可以被别人访问到,搭建服务器必备
			
我么一般配置虚拟机的时候,我们总是喜欢使用虚拟网段,但是这样别人有可能ping不通我的虚拟机的. 若是我们想要别人ping我们的ip ,则我们要跟改以下几个操作: 在我们的网络源的源模式中,你若是想在 ...
 - 在Eclipse中开发WEB项目
			
本文的演示是从本地文件创建dynamic web project,从svn检出的同时创建dynamic web project于此类似.我们推荐使用解压版的tomcat6.x版本,来作为服务器.可以到 ...
 - Windows配置java运行环境的步骤
			
jdk不同版本下载地址:http://www.oracle.com/technetwork/java/javase/archive-139210.html 1.下载你适合你电脑的jdk版本,链接如上, ...
 - mysql导出/导入表结构以及表数据
			
导出: 命令行下具体用法如下: mysqldump -u用戶名 -p密码 -d 数据库名 表名 脚本名; 1.导出数据库为dbname的表结构(其中用戶名为root,密码为dbpasswd,生成的脚 ...
 - utuntu下安装eclipse+jdk
			
安装jdk: 1.下载一个可以用的jdk压缩包.下载地址:http://www.oracle.com/technetwork/java/javase/downloads/jdk7-downloads- ...
 - ubuntu下搭建openGL环境
			
1. 建立基本编译环境 sudo apt-get install build-essential 2. 安装OpenGL Library sudo apt-get install ...
 - 洛谷 P4139 上帝与集合的正确用法
			
题目描述 根据一些书上的记载,上帝的一次失败的创世经历是这样的: 第一天, 上帝创造了一个世界的基本元素,称做“元”. 第二天, 上帝创造了一个新的元素,称作“α”.“α”被定义为“元”构成的集合.容 ...
 - JS中数组和字符串具有的方法,以及substring,substr和slice的用法与区别
			
String 对象属性 属性 描述 constructor 对创建该对象的函数的引用 length 字符串的长度 prototype 允许您向对象添加属性和方法 String 对象方法 方法 描述 ...
 - 【bzoj4869】相逢是问候
			
Portal-->bzoj4869 Solution 这道题的话..长得就是线段树的样子qwq 如果做过的话..可能会联想到bzoj3211(没写博qwq晚点再说吧哈哈..) 首先大胆猜一波结论 ...
 - Hdu5693 D Game
			
D Game Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Subm ...