绿豆蛙的归宿 期望dp+拓扑排序
时间:2022-06-19
本文章向大家介绍绿豆蛙的归宿 期望dp+拓扑排序,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
对第i个点,f[i]表示i到终点的期望路径总长。
则f[n] = 0; 终点确定,则逆推。
对点x-->y
f[ x ] = sigema( f[ y ] + w(x,y) )/out[ x ];
out[x]表示出度,把它变成入度就反向建图,为了拓扑。
#include <bits/stdc++.h>
using namespace std;
const int M = 200500;
struct Edge{
int nxt,v;
double val;
};
Edge edge[M];
double in[M],dg[M];
double f[M];
int n,m,cnt,head[M];
void add(int u,int v,double w){
cnt++;
edge[cnt].v = v;
edge[cnt].val = w;
edge[cnt].nxt = head[u];
head[u] = cnt;
}
int read(){
int x=0,dign=1;
char c = getchar();
while(c<'0'||c>'9'){
if(c=='-')dign=-1;
c = getchar();
}
while(c>='0'&&c<='9'){
x = x*10+c-'0';
c = getchar();
}
return x*dign;
}
void spfa(){
queue<int> q;
for(int i=1;i<=n;i++)if(!in[i])q.push(i);
while(!q.empty()){
int u = q.front(); q.pop();
for(int v,i=head[u];i;i=edge[i].nxt){
double w = edge[i].val;
v = edge[i].v;
f[v]+=(f[u]+w)/dg[v];
in[v]--;
if(!in[v])q.push(v);
}
}
}
int main()
{
n = read(); m = read();
for(int i=0;i<m;i++){
int u,v;double w;
u = read(); v=read(); scanf("%lf",&w);
add(v,u,w);//反向建图
in[u]++; dg[u]++;
}
spfa();
printf("%.2lf",f[1]);
return 0;
}
- 网卡收包流程
- Android 异步加载图片,使用LruCache和SD卡或手机缓存,效果非常的流畅
- Terminal &zsh &oh-my-zsh配置
- 【Python量化投资】基于网格优化、遗传算法对CTA策略进行参数优化
- 将我的 Windows Phone 应用程序更新到 Windows Phone 8
- 绑定子类的泛型基类,反模式?
- 给创业码农的话--如何提升开发效率
- 基于OEA框架的客户化设计(二) 元数据设计
- 自定义actionbar
- (转)JS算法系列-数组去重
- 基于OEA框架的客户化设计(三) “插件式”DLL
- 居中“魔法”总结
- Windows微信DPI适配
- 采用Symbol和process.nextTick实现Promise
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 指针作形参,需要注意的问题。
- SetConsoleTextAttribute函数用法
- C语言俄罗斯方块(旧版本)
- 线性表--顺序表--数组(三)
- 算法复杂度(二)
- 线性表--顺序表--单向链表(四)
- C语言俄罗斯方块(新版本完整代码)
- 线性表--顺序表--双向链表(六)
- C/C++什么时候使用二级指针,你知道吗?
- 萌新学习C++容易漏掉的知识点,看看你中招了没有(一)
- 萌新不看会后悔的C++string字符串常用知识点总结
- salesforce零基础学习(九十六)项目中的零碎知识点小总结(四)
- CodeForces - 260C
- 疯子的算法总结(九) 图论中的矩阵应用 Part 2 矩阵树 基尔霍夫矩阵定理 生成树计数 Matrix-Tree
- STL常用对象,不会搞得C++跟没学一样