1065. [Nescafe19] 绿豆蛙的归宿

★   输入文件:ldfrog.in   输出文件:ldfrog.out   简单对比
时间限制:1 s   内存限制:128 MB

【背景】

随着新版百度空间的下线,Blog宠物绿豆蛙完成了它的使命,去寻找它新的归宿。

【题目描述】

给出一个有向无环的连通图,起点为1终点为N,每条边都有一个长度。绿豆蛙从起点出发,走向终点。
到达每一个顶点时,如果有K条离开该点的道路,绿豆蛙可以选择任意一条道路离开该点,并且走向每条路的概率为 1/K 。
现在绿豆蛙想知道,从起点走到终点的所经过的路径总长度期望是多少?

【输入格式】

第一行: 两个整数 N M,代表图中有N个点、M条边
第二行到第 1+M 行: 每行3个整数 a b c,代表从a到b有一条长度为c的有向边

【输出格式】

从起点到终点路径总长度的期望值,四舍五入保留两位小数。

【输入样例】

4 4
1 2 1
1 3 2
2 3 3
3 4 4

【输出样例】

7.00

【时限】

各个测试点1s

【数据范围】

对于20%的数据   N<=100
对于40%的数据   N<=1000
对于60%的数据   N<=10000
对于100%的数据  N<=100000,M<=2*N

/*
期望=概率*贡献.
然后把贡献停留在点上最后累加.
*/
#include<cstdio>
using namespace std;
const int N=1e5+;
struct edge{int v,w,next;}e[N<<];int tot,head[N];
int m,n,out[N];
double s[N],ans[N],res;
void add(int x,int y,int z){
e[++tot].v=y;
e[tot].w=z;
e[tot].next=head[x];
head[x]=tot;
}
void dp(int x){
for(int i=head[x];i;i=e[i].next){
int v=e[i].v;
s[v]=s[x]/out[x];
dp(v);
ans[x]+=s[v]*e[i].w;
}
}
int main(){
freopen("ldfrog.in","r",stdin);
freopen("ldfrog.out","w",stdout);
scanf("%d%d",&n,&m);
for(int i=,x,y,z;i<=m;i++){
scanf("%d%d%d",&x,&y,&z);
add(x,y,z);out[x]++;
}
s[]=;
dp();
for(int i=;i<=n;i++) res+=ans[i];
printf("%.2lf",res);
return ;
}

最新文章

  1. jmeter(九)逻辑控制器
  2. 关于u32中查找和定位最后到bit Number of 1 Bits
  3. [Socket网络编程]一个封锁操作被对 WSACancelBlockingCall 的调用中断。
  4. symfony中twig的模板变量与注释
  5. C语言实现词频统计——第二版
  6. EnCase v7 could not recognize Chinese character folder names / file names on Linux Platform
  7. ASP.NET MVC4 View层_Razor操作Html元素
  8. 博客标题栏增加一个&quot;闪存“按钮
  9. linux下C++开发工具
  10. ERP-非财务人员的财务培训教(一.一)------基本会计知识
  11. docker(二) windows10下安装docker
  12. 了解Activity生命周期
  13. boolean表达式与在if条件中的运用
  14. echarts2 饼图处理标签文字过长使之达到指定字数换行的目的
  15. 20180820 JS 片段
  16. Scala函数式对象-有理数
  17. Eclipse的快捷键使用总结
  18. Confluence 6 使用 LDAP 授权连接一个内部目录 - 用户组 Schema 设置
  19. CentOS 安装第三方yum源
  20. angular-translate国际化

热门文章

  1. leetcode题解:Construct Binary Tree from Preorder and Inorder Traversal (根据前序和中序遍历构造二叉树)
  2. ol 接入百度地图
  3. 从头认识java-14.4 Java提供的数组的有用功能(2)
  4. [转载]How to Install Google Chrome 39 in CentOS/RHEL 6 and Fedora 19/18
  5. 如何使用CodeSmith批量生成代码
  6. Node.js 使用jQuery取得Nodejs http服务端返回的JSON数组示例
  7. 熟悉jauery库中的构造函数 jQuery()
  8. HTML 5 音频Audio
  9. Odoo 8,9,10 制造领料、入库 实践
  10. 【VBA】复制单元格数据有效性