Luogu2164 SHOI2007 交通网络 期望、BFS、拓扑排序
题目还算不难吧
首先我们枚举点$i$,将其他所有点到这个点的最短路求出来
然后我们在这一次建出的最短路$DAG$的反图上进行拓扑排序。假设我们算到了点$j$,点$j$的人流量为$t_j$,点$j$连出去的边到达的点为点集$\{v\}$,那么对于每一个点$u \in \{v\}$,边$(j,u)$的流量就会增加$\frac{t_j}{|\{v\}|}$,$t_u$会加上$\frac{t_j}{|\{v\}|}$
总时间复杂度$O(N^2)$
#include<bits/stdc++.h>
#define ld long double
using namespace std;
inline int read(){
;
char c = getchar();
while(!isdigit(c)) c = getchar();
) + (a << ) + (c ^ ') , c = getchar();
return a;
}
inline int max(int a , int b){
return a > b ? a : b;
}
struct Ed{
int start , end , upEd;
}ans[];
] , ifRail[][];
];
] , minRoute[];
ld peo[][] , To[][];
struct cmp{
bool operator() (const int& a, const int& b ){
return minRoute[a] < minRoute[b];
}
};
int main(){
int N = read() , M = read();
; i <= M ; i++){
int a = read() , b = read();
ans[(i << ) - ].start = a;
ans[(i << ) - ].end = b;
ans[(i << ) - ].upEd = firEd[a];
firEd[a] = (i << ) - ;
ans[i << ].start = b;
ans[i << ].end = a;
ans[i << ].upEd = firEd[b];
firEd[b] = i << ;
ifRail[a][b] = ifRail[b][a] = ;
}
; i <= N ; i++)
; j <= N ; j++) To[i][j] = read();
; i <= N ; i++){
memset(minRoute , 0x3f , sizeof(minRoute));
memset(Times , , sizeof(Times));
minRoute[i] = ;
Times[i] = ;
queue < int > q;
priority_queue < int , vector < int > , cmp > q1;
q.push(i);
while(!q.empty()){
int t = q.front();
q.pop();
;
for(int j = firEd[t] ; j ; j = ans[j].upEd)
){
minRoute[ans[j].end] = minRoute[t] + ;
Times[ans[j].end] = Times[t];
q.push(ans[j].end);
f = ;
}
){
Times[ans[j].end] += Times[t];
f = ;
}
if(!f) q1.push(t);
}
memset(vis , , sizeof(vis));
vis[i] = ;
while(!q1.empty()){
int t = q1.top();
q1.pop();
; j <= N ; j++)
){
ld t1 = (ld)To[i][t] * Times[j] / Times[t];
peo[j][t] += t1;
peo[t][j] += t1;
To[i][j] += t1;
if(!vis[j]){
vis[j] = ;
q1.push(j);
}
}
}
}
; i <= M ; i++)
cout << ) << peo[ans[i << ].start][ans[i << ].end] + 1e- << endl;
;
}
Luogu2164 SHOI2007 交通网络 期望、BFS、拓扑排序的更多相关文章
- [LuoguP2164][SHOI2007]交通网络_拓扑排序_概率期望
交通网络 题目链接:https://www.luogu.org/problemnew/solution/P2164 数据范围:略. 题解: 直接算不好算,我们考虑建反图然后$Toposort$. 这样 ...
- C. Journey bfs 拓扑排序+dp
C. Journey 补今天早训 这个是一个dp,开始我以为是一个图论,然后就写了一个dij和网络流,然后mle了,不过我觉得如果空间开的足够的,应该也是可以过的. 然后看了题解说是一个dp,这个dp ...
- uvaLA4255 Guess BFS+拓扑排序
算法指南白书 思路:“连续和转化成前缀和之差” #include <stdio.h> #include <string.h> #include <iostream> ...
- hihoCoder1343 : Stable Members【BFS拓扑排序】
题目链接:https://hihocoder.com/problemset/problem/1343 #1343 : Stable Members 时间限制:10000ms 单点时限:1000ms 内 ...
- CH 2101 - 可达性统计 - [BFS拓扑排序+bitset状压]
题目链接:传送门 描述 给定一张N个点M条边的有向无环图,分别统计从每个点出发能够到达的点的数量.N,M≤30000. 输入格式 第一行两个整数N,M,接下来M行每行两个整数x,y,表示从x到y的一条 ...
- hihocoder 1174 [BFS /拓扑排序判断是否有环]
hihocoder 1174 [算法]: 计算每一个点的入度值deg[i],这一步需要扫描所有点和边,复杂度O(N+M). 把入度为0的点加入队列Q中,当然有可能存在多个入度为0的点,同时它们之间也不 ...
- Going from u to v or from v to u?_POJ2762强连通+并查集缩点+拓扑排序
Going from u to v or from v to u? Time Limit: 2000MS Memory Limit: 65536K Description I ...
- 【ZOJ - 3780】 Paint the Grid Again (拓扑排序)
Leo has a grid with N × N cells. He wants to paint each cell with a specific color (either black or ...
- [LeetCode] 207. 课程表(拓扑排序,BFS)
题目 现在你总共有 n 门课需要选,记为 0 到 n-1. 在选修某些课程之前需要一些先修课程. 例如,想要学习课程 0 ,你需要先完成课程 1 ,我们用一个匹配来表示他们: [0,1] 给定课程总量 ...
随机推荐
- Openlayer3之瓦片数据接入
瓦片数据集接入实现思路: 1.构造ol.source.TileImage数据源,构造该数据源需要以下几项: 1)空间参考,通过如下代码构造 2)TileGrid,构造需要以下几项: a)原点 b)分辨 ...
- How to deploy kotlin in androidstudio?
Kotlin is a good language,more playable than Java.So how do we deploy kotlin? First,install the kotl ...
- mysql的高级特性-存储过程
定义: 存储例程是存储在数据库服务器中的一组sql语句,通过在查询中调用一个指定的名称来执行这些sql语句命令. 语法: DELIMITER // 声明语句结束符,用于区分; CEATE PROCED ...
- 使用wxpy自动发送微信消息
思路整理:1.进入心灵鸡汤网页,使用python获取心灵鸡汤内容 2.登陆微信,找到需要发送的朋友 3.发送获取的内容 1.获取心灵鸡汤的内容 如下图,获取第一条鸡汤 实现如下: 2.登陆微信,搜索朋 ...
- NAudio音频文件转换
1.NuGet安装 NAudio,项目及demo的网址:https://github.com/naudio/NAudio Encode to MP3, WMA and AAC with MediaFo ...
- zTree 优秀的jquery树插件
zTree 优秀的jquery树插件,文档详细,渲染快 使用方法: 1.引用zTree的js和css文件 <link href="~/Content/zTree_v3/css/zTre ...
- jQuery 实现图片动画代码
向下移动动画 $(".image").click(function(){ $(this).animate({height:'0px'}) }); <!doctype html ...
- Mvc检查图片格式后上传
/// <summary> /// 检查是否文件是否图片并保存 /// </summary> /// <param name="file">文件 ...
- 字符串通过在配置文件配置三个key来进行加密解密
在这里和大家分享一个加密util,相对于md5加密相信大家都已经很熟悉了吧,md5是不可逆的一种加密方式,虽说不可逆但是网上已经有了破解的方法,我这边分享一个免费的破解 网址给大家:https://w ...
- OpenLdap 对接内部系统(Gitlab+Wiki+Jumpserver+Openvpn)配置
LDAP 全称轻量级目录访问协议(英文:Lightweight Directory Access Protocol),是一个运行在 TCP/IP 上的目录访问协议.目录是一个特殊的数据库,它的数据经常 ...