小A的旅行(绿豆蛙的归宿)【期望DP】
Description
给出一个有向无环的连通图,起点为1,终点为N,每条边都有一个长度。小A从起点出发,走向终点。
到达每一个顶点时,如果有K条离开该点的道路,小A可以选择任意一条道路离开该点,并且走向每条路的概率为 1/K 。
现在小A想知道,从起点走到终点的所经过的路径总长度期望是多少?
Input
第一行: 两个整数 N M,代表图中有N个点、M条边
第二行到第 1+M 行: 每行3个整数 a b c,代表从a到b有一条长度为c的有向边
Output
从起点到终点路径总长度的期望值,四舍五入保留两位小数。
Sample Input
4 4
1 2 1
1 3 2
2 3 3
3 4 4
Sample Output
7.00
Hint
对于30%的数据 N<=50
对于70%的数据 N<=1000
对于100%的数据 N<=100000,M<=2*N,边权<=1000
-----------------------------------
测试数据:https://files.cnblogs.com/files/Syameimaru/tour.zip
-------------------------------------------------------------------------------------------------------
题解:
对于这道题,我们很容易想到,用动态规划的思想解决有关期望的问题。
可以观察到,每个店的期望值,都只与他的子节点有关,具体关系为:
f[i]=(f[j]+w)/d[i]
其中,f[i[表示从i节点,到达终点的路径的期望。
注意,这里我们不用f[i]表示到达i点概率的期望值,因为如果这样表示,会导致状态转移代价过大,使算法不够优秀,并且有更多的细节(只考虑能够到大的父节点计算入度),不够优秀,所以我们才用倒序来推。
时间复杂度 O(n),我们可以按照拓扑序倒序来转移。
当然,我们没必要真的进行拓扑排序,记忆化dp就好
下面是胡搞的代码:
#include<cstdio>
#include<cstring>
#include<vector>
#include<queue>
#define rep(i,a,b) for(register int i = (a);i<=(b);++i)
const int maxn = ;
struct Edge {
int v,dist;
Edge(int v,int dist):v(v),dist(dist){}
};
std::vector<Edge> edges;
std::vector<int> G1[maxn],G2[maxn];
std::queue<int> Q,Q2;
double f[maxn];
int n,m,a,b,v,inq[maxn],tp[maxn];
double dfs(int x) {
if(f[x]) return f[x];
if(x==n) return ;
for(register int i=;i<G1[x].size();i++) {
Edge e = edges[G1[x][i]];
f[x]+=dfs(e.v)+e.dist;
}
f[x]/=G1[x].size();
return f[x];
}
int main() {
freopen("tour.in","r",stdin);
freopen("tour.out","w",stdout);
scanf("%d%d",&n,&m);
rep(i,,m){
scanf("%d%d%d",&a,&b,&v);
inq[b]++;edges.push_back(Edge(b,v));
edges.push_back(Edge(a,v));
int num = edges.size();
G1[a].push_back(num-);
G2[b].push_back(num-);
}
dfs();
printf("%.2lf",f[]);
return ;
}
小A的旅行(绿豆蛙的归宿)【期望DP】的更多相关文章
- P4316 绿豆蛙的归宿 期望DP
		
P4316 绿豆蛙的归宿 期望DP DAG上,每条边有边权,走向相连每条路的概率相等,问从起点到终点所经过的路径总长度期望 因为发现终点走到终点期望为0,定义\(f[i]\)从终点走到\(i\)所经过 ...
 - BZOJ 3036: 绿豆蛙的归宿( 期望dp )
		
从终点往起点倒推 . 在一个图 考虑点 u , 出度为 s : s = 0 , d[ u ] = 0 ; s ≠ 0 , 则 d( u ) = ( ∑ d( v ) ) / s ( ( u , v ) ...
 - 【bzoj3036】绿豆蛙的归宿  期望dp
		
题目描述 随着新版百度空间的下线,Blog宠物绿豆蛙完成了它的使命,去寻找它新的归宿. 给出一个有向无环的连通图,起点为1终点为N,每条边都有一个长度.绿豆蛙从起点出发,走向终点.到达每一个顶点时,如 ...
 - Luogu4316 | 绿豆蛙的归宿 (期望DP)
		
题目背景 随着新版百度空间的上线,Blog宠物绿豆蛙完成了它的使命,去寻找它新的归宿. 题目描述 给出一个有向无环图,起点为1终点为N,每条边都有一个长度,并且从起点出发能够到达所有的点,所有的点也都 ...
 - Bzoj 3036: 绿豆蛙的归宿(期望)
		
3036: 绿豆蛙的归宿 Time Limit: 2 Sec Memory Limit: 128 MB Description 随着新版百度空间的下线,Blog宠物绿豆蛙完成了它的使命,去寻找它新的归 ...
 - 洛谷P4316 绿豆蛙的归宿(期望)
		
题意翻译 「Poetize3」 题目背景 随着新版百度空间的上线,Blog宠物绿豆蛙完成了它的使命,去寻找它新的归宿. 题目描述 给出一个有向无环图,起点为1终点为N,每条边都有一个长度,并且从起点出 ...
 - BZOJ 3036: 绿豆蛙的归宿 期望 + 拓扑排序
		
随着新版百度空间的下线,Blog宠物绿豆蛙完成了它的使命,去寻找它新的归宿.给出一个有向无环的连通图,起点为1终点为N,每条边都有一个长度.绿豆蛙从起点出发,走向终点. 到达每一个顶点时,如果有K条离 ...
 - 【BZOJ3036】绿豆蛙的归宿 概率DP
		
链接: #include <stdio.h> int main() { puts("转载请注明出处[辗转山河弋流歌 by 空灰冰魂]谢谢"); puts("网 ...
 - 洛谷P4316绿豆蛙的归宿——期望
		
题目:https://www.luogu.org/problemnew/show/P4316 期望水题,从终点向起点推,因为是DAG,所以拓扑序推过去即可. 代码如下: #include<ios ...
 - 洛谷$P4316$ 绿豆蛙的归宿 期望
		
正解:期望 解题报告: 传送门! 看懂题目还是挺水的$(bushi$ 三个方法,但因为题目太水了懒得一一介绍了,,,反正都是期望,,,$so$随便港个最简单的趴$QwQ$ 直接考虑每条边的贡献,就会是 ...
 
随机推荐
- 关于document.cookie的使用
			
设置cookie每个cookie都是一个名/值对,可以把下面这样一个字符串赋值给document.cookie:document.cookie="userId=828";如果要一次 ...
 - java中回调函数的使用
			
package com.huawei.common; import java.sql.ResultSet;import java.sql.SQLException; /** * 回调函数 * @aut ...
 - 如何阅读一个Web项目 【转载】
			
摘自网络博客. ============================================================================================ ...
 - 27-python 画图
			
绝佳教程:http://pyecharts.org/#/zh-cn/prepare?id=%E4%BD%BF%E7%94%A8%E4%B8%BB%E9%A2%98安装 pyecharts pip in ...
 - 使用Log4J监控系统日志邮件警报
			
使用Log4J监控系统日志邮件警报 前言 在系统上线后,有时候遇到系统故障,这时候就可以登录服务器查看系统日志来排查问题.但是需要登录服务器,下载查找相关异常日志比较麻烦.而且没有监控的话,也无法实时 ...
 - Golang之实现一个负载均衡算法(随机,轮询)
			
代码记录 程序结构目录 --------程序包 package balance type Balancer interface { DoBalance([]*Instance, ...string) ...
 - An interview question from MicroStrategy
			
去年校招时的一道面试题,觉得蛮有意思,贴出来. Question: Spy start at a, during an interval he moves |b| to right when b &g ...
 - linux git server 简易搭建 (ssh访问)
			
git的服务器搭建,如果无需权限控制,仅团队内部使用,初始化一个服务器仓库,其他人通过ssh访问这个文件夹即可.如需复杂的管理,建议使用gitlab. yum install git -y id gi ...
 - C#分布式事务解决方案-TransactionScope(转)
			
出处:C#分布式事务解决方案-TransactionScope 引用一下别人的导读:在实际开发工作中,执行一个事件,然后调用另一接口插入数据,如果处理逻辑出现异常,那么之前插入的数据将成为垃圾数据,我 ...
 - Windows 环境下分布式跨域Session共享(转)
			
出处:http://www.cnblogs.com/stangray/p/3328092.html 为什么还是那句话,在网上找了N篇Session共享,但真正可以直接解决问题的还是没有找到. 一.以下 ...