BZOJ1491: [NOI2007]社交网络(Floyd 最短路计数)
Time Limit: 10 Sec Memory Limit: 64 MB
Submit: 2343 Solved: 1266
[Submit][Status][Discuss]
Description
.png)
Input
Output
输出包括n行,每行一个实数,精确到小数点后3位。第i行的实数表示结点i在社交网络中的重要程度。
Sample Input
1 2 1
2 3 1
3 4 1
4 1 1
Sample Output
1.000
1.000
1.000
HINT
社交网络如下图所示。
.png)
Source
最短路计数。。
mdzz想到一个做法,应该是$N^3$的,不过与边权有关,然后被卡成$90$分卡成一下午。。
就是直接dfs求最短路计数的时候统计答案,但是不能写记忆化。会wa
// luogu-judger-enable-o2
#include<cstdio>
#include<vector>
#include<algorithm>
#include<cstring>
#include<map>
#include<cmath>
using namespace std;
const int MAXN = 1e5 + , INF = 1e8 + ;
inline int read() {
char c = getchar(); int x = , f = ;
while(c < '' || c > '') {if(c == '-') f = -; c = getchar();}
while(c >= '' && c <= '') x = x * + c - '', c = getchar();
return x * f;
}
int N, M;
int dis[][], f[][], num[][][], w[][];
void Floyed() {
for(int k = ; k <= N; k++) {
dis[k][k] = ;
for(int i = ; i <= N; i++)
for(int j = ; j <= N; j++)
dis[i][j] = min(dis[i][j], dis[i][k] + dis[k][j]);
}
}
int GetAns(int bg, int now, int pre) {
int ans = ;
if(bg == now) return ;
for(int i = ; i <= N; i++) {
if(now != i && dis[bg][now] == dis[bg][i] + w[i][now]) {
int x = GetAns(bg, i, pre);
num[bg][pre][i] += x;
ans += x;
}
}
return ans;
}
double ans[MAXN];
main() {
#ifdef WIN32
freopen("a.in", "r", stdin);
//freopen("a.out", "w", stdout);
#endif
N = read(); M = read();
memset(dis, 0x3f, sizeof(dis));
memset(w, 0x3f, sizeof(w));
for(int i = ; i <= M; i++) {
int x = read(), y = read(), z = read();
w[x][y] = w[y][x] = dis[x][y] = dis[y][x] = z;
}
Floyed(); for(int i = ; i <= N; i++) {
f[i][i] = ;
for(int j = ; j <= N; j++)
f[i][j] = GetAns(i, j, j);
} for(int i = ; i <= N; i++) {
double ans = ;
for(int s = ; s <= N; s++) {
for(int t = ; t <= N; t++)
if(s != i && t != i && s != t)
ans += (double)num[s][t][i] / f[s][t];
}
printf("%.3lf\n", ans);
}
return ;
}
90
标算是Floyd最短路计数,
// luogu-judger-enable-o2
// luogu-judger-enable-o2
#include<cstdio>
#include<vector>
#include<algorithm>
#include<cstring>
#include<map>
#include<cmath>
#define LL long long
using namespace std;
const int INF = 1e9 + ;
inline int read() {
char c = getchar(); int x = , f = ;
while(c < '' || c > '') {if(c == '-') f = -; c = getchar();}
while(c >= '' && c <= '') x = x * + c - '', c = getchar();
return x * f;
}
int N, M;
LL dis[][], num[][];
double ans[];
void Floyed() {
for(int k = ; k <= N; k++) {
for(int i = ; i <= N; i++)
for(int j = ; j <= N; j++) {
int to = dis[i][k] + dis[k][j];
if(to == INF) continue;
if(to < dis[i][j])
dis[i][j] = to, num[i][j] = num[i][k] * num[k][j];
else if(to == dis[i][j])
num[i][j] += num[i][k] * num[k][j];
}
}
for(int i = ; i <= N; i++) {
for(int s = ; s <= N; s++) {
for(int t = ; t <= N; t++) {
if(s == i || t == i || (dis[s][i] + dis[i][t] != dis[s][t]) || s == t) continue;
ans[i] += (double)(1.0 * num[s][i] * num[i][t]) / num[s][t];
}
}
}
}
int main() {
N = read(); M = read();
for(int i = ; i <= N; i++)
for(int j = ; j <= N; j++)
dis[i][j] = INF;
for(int i = ; i <= M; i++) {
int x = read(), y = read(), z = read();
dis[x][y] = dis[y][x] = z;
num[x][y] = num[y][x] = ;
}
Floyed();
for(int i = ; i <= N; i++)
printf("%.3lf\n", ans[i]);
return ;
}
BZOJ1491: [NOI2007]社交网络(Floyd 最短路计数)的更多相关文章
- 1491. [NOI2007]社交网络【最短路计数】
Description 在社交网络(socialnetwork)的研究中,我们常常使用图论概念去解释一些社会现象.不妨看这样的一个问题. 在一个社交圈子里有n个人,人与人之间有不同程度的关系.我们将这 ...
- [BZOJ1491][NOI2007]社交网络 floyd
1491: [NOI2007]社交网络 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 2196 Solved: 1170[Submit][Status ...
- 【BZOJ1491】[NOI2007]社交网络 Floyd
[BZOJ1491][NOI2007]社交网络 Description 在社交网络(socialnetwork)的研究中,我们常常使用图论概念去解释一些社会现象.不妨看这样的一个问题. 在一个社交圈子 ...
- BZOJ 1491: [NOI2007]社交网络( floyd )
floyd...求最短路时顺便求出路径数. 时间复杂度O(N^3) ------------------------------------------------------------------ ...
- [NOI2007]社交网络(最短路)
[NOI2007]社交网络 Description 在社交网络(socialnetwork)的研究中,我们常常使用图论概念去解释一些社会现象.不妨看这样的一个问题. 在一个社交圈子里有n个人,人与人之 ...
- 洛谷P2047||bzoj1491 [NOI2007]社交网络
https://www.luogu.org/problemnew/show/P2047 https://www.lydsy.com/JudgeOnline/problem.php?id=1491 也可 ...
- BZOJ1491 [NOI2007]社交网络[最短路计数]
$n$非常的小,结合题目计算式可以想到$O(n^3)$暴枚$s,t,v$,看$v$在不在$s\to t$最短路上($dis_{s,v}+dis_{v,t}=dis_{s,v}$是$v$在两点最短路上的 ...
- BZOJ1491 [NOI2007]社交网络 【floyd】
题目 在社交网络(socialnetwork)的研究中,我们常常使用图论概念去解释一些社会现象.不妨看这样的一个问题. 在一个社交圈子里有n个人,人与人之间有不同程度的关系.我们将这个关系网络对应到一 ...
- 【Floyd】BZOJ1491: [NOI2007]社交网络
Description Solution n<=100自然联想Floyd 设两个数组d[n][n]存最短距离,t[n][n]存最短路径条数 更新d的时候顺便更新t,乘法原理 if(d[i][ ...
随机推荐
- mysql 8 修改root 密码
主要参考:https://dev.mysql.com/doc/refman/8.0/en/resetting-permissions.html 需要注意的是创建文件的时候需要保存为 utf-8 无 B ...
- GET和POST区别和用法
很多人都分不清GET与POST的区别,以及什么时候用GET?什么时候用POST? GET和POST两种方法都是将数据送到服务器,但你该用哪一种呢? HTTP标准包含这两种方法是为了达到不同的目的.PO ...
- ip地址在通信中的变化(就简单的讲一下, 给自己mark)
节点之间的通信 数据报文的封装(自上而下) http tcp ip mac(讯框) 数据报文的源ip和目标ip是不变的(在内网中, 如果考虑到连接到外部网路的时候, 如果有路由器(里面有嵌入式的Lin ...
- node搭环境(三)之安装vue-devtools
前面已经安装了bower gulp,马上要学vue了,今天安装vue及调试神器vue-devtools 安装步骤: 1.在GitHub上输入 github.com/vuejs/vue-devtool后 ...
- jq实例
1.导航栏 <style type="text/css"> * {padding:0;margin:0;list-style:none;} img { width:11 ...
- 动态行转列 pivot实现
declare @sql varchar(8000) begin set @sql='' --初始化变量@sql select @sql= ...
- 粗看ES6之JSON
标签: es6 ES6新增JSON特性不是特别多,只是针对JSON某些情况下的写法上有一些优化: 当key值和value值对应变量名相同时 json对像中的方法书写 示例代码如下: <!DOCT ...
- 【起航计划 027】2015 起航计划 Android APIDemo的魔鬼步伐 26 App->Preferences->Preferences from XML 偏好设置界面
我们在前面的例子Android ApiDemo示例解析(9):App->Activity->Persistent State 介绍了可以使用Shared Preferences来存储一些状 ...
- Unity Shader 阴影
最近在看Unity shader开发实战详解,刚开始看阴影部分,稍微有了点思路.在这里写点笔记,算是小结吧. .阴影实现方法 一种是通过模拟光照的原理,用向量的方法 找到被光线照射的点 映射到平面的位 ...
- Struts2_HelloWorld_7_1
大致了解应用的运行过程: 由请求路径开始,浏览器端通过URL向tomcat发送http请求(如:http://localhost:8080/Struts2_0100_Introduction/hell ...