7-11 社交网络图中结点的“重要性”计算 (30 分)(Dijkstra算法)
题意:

思路:对每个输入的点跑一遍dijkstra算法,然后对这个点到所有点的距离求和按公式输出就可以了。
(这次尝试了用数组模拟链表来做最短路问题,刷新了自己对最短路的理解)

这里构造链表的过程我的理解一直有误差,第一行的式子中参与代码构建的是Next[cnt] = head[y];head[y] = cnt++;这两个语句。而前边的只是存了编号为cnt的边的另一个端点和这条边的花费。
讲解见大佬博客:https://blog.csdn.net/major_zhang/article/details/52155279
代码:
#include <iostream>
#include <queue>
#include <cstdio>
#include <algorithm>
#include <cmath>
#include <cstring>
#include <queue>
#include <vector>
#define INF 0x3f3f3f3f
#define FRE() freopen("in.txt","r",stdin) using namespace std;
typedef long long ll;
typedef pair<int,string> P;
const int maxn = ;
int Next[maxn],head[maxn],u[maxn],cost[maxn];
int dist[maxn],vis[maxn];
int n,m; int cnt = ;
void InsertEdge(int x,int y) {
u[cnt] = x;cost[cnt] = ;Next[cnt] = head[y];head[y] = cnt++;
u[cnt] = y;cost[cnt] = ;Next[cnt] = head[x];head[x] = cnt++;
} void init() {
memset(head,-,sizeof(head));
scanf("%d%d",&n,&m);
for(int i = ; i<m; i++) {
int st,en;
scanf("%d%d",&st,&en);
InsertEdge(st,en);
}
} void Dijkstra(int v) {
memset(dist,INF,sizeof(dist));
for(int i = head[v]; ~i ; i = Next[i]) {
dist[u[i]] = cost[i];
}
memset(vis,,sizeof(vis));
vis[v] = ;
dist[v] = ;
while() {
int t = -;
for(int i = ; i<=n; i++) {//寻找当前点的序列中还没有访问的最小的距离的点,这里的i指的是点
if(!vis[i] && (t==- || dist[t]>dist[i]))
t = i;
}
if(t == -)
break;
vis[t] = ;
for(int i = head[t]; ~i; i = Next[i]) {//从与该点相连的边找最小的花费,这里的i其实是表示的标号cnt
if(dist[u[i]] > dist[t]+cost[i]){
dist[u[i]] = dist[t]+cost[i];
}
//dist[u[i]] = min(dist[u[i]], dist[t]+cost[i]);
}
}
bool ok = false;
int sum = ;
for(int i = ; i<=n; i++) {
if(dist[i]==INF) {
ok = true;
//cout<<"GG"<<endl;
break;
}
sum += dist[i];
}
// printf("sum: %d n: %d\n",sum,n); if(ok)
printf("Cc(%d)=0.00\n",v);
else
printf("Cc(%d)=%.2f\n",v,(1.0*(n-))/(1.0*sum));
} int main() {
//FRE();
int n,m;
init();
int num,t;
scanf("%d",&num);
for(int i = ; i<num; i++) {
scanf("%d",&t);
Dijkstra(t);
}
return ;
}
7-11 社交网络图中结点的“重要性”计算 (30 分)(Dijkstra算法)的更多相关文章
- 社交网络图中结点的“重要性”计算 (30 分) C++解法
社交网络图中结点的"重要性"计算 (30 分) 在社交网络中,个人或单位(结点)之间通过某些关系(边)联系起来.他们受到这些关系的影响,这种影响可以理解为网络中相互连接的结点之间蔓 ...
- PTA数据结构与算法题目集(中文) 7-36 社交网络图中结点的“重要性”计算 (30 分)
PTA数据结构与算法题目集(中文) 7-36 社交网络图中结点的“重要性”计算 (30 分) 7-36 社交网络图中结点的“重要性”计算 (30 分) 在社交网络中,个人或单位(结点)之间通过某 ...
- PTA 社交网络图中结点的“重要性”计算(30 分)
7-12 社交网络图中结点的“重要性”计算(30 分) 在社交网络中,个人或单位(结点)之间通过某些关系(边)联系起来.他们受到这些关系的影响,这种影响可以理解为网络中相互连接的结点之间蔓延的一种相互 ...
- PTA 7-12(图) 社交网络图中结点的“重要性”计算 最短路
7-12(图) 社交网络图中结点的“重要性”计算 (30 分) 在社交网络中,个人或单位(结点)之间通过某些关系(边)联系起来.他们受到这些关系的影响,这种影响可以理解为网络中相互连接的结点之间蔓延的 ...
- 7-10 社交网络图中结点的“重要性”计算(30 point(s)) 【并查集+BFS】
7-10 社交网络图中结点的"重要性"计算(30 point(s)) 在社交网络中,个人或单位(结点)之间通过某些关系(边)联系起来.他们受到这些关系的影响,这种影响可以理解为网络 ...
- PAT-1018(Public Bike Management)最短路+额外条件+所有最短路中找出满足条件的路径+dijkstra算法
Public Bike Management PAT-1018 使用一个vector来存储所有最短路的前驱结点,再通过使用dfs和一个额外的vector记录每一条路径 #include<iost ...
- 測试oracle 11g cluster 中OLR的重要性
測试oracle 11g cluster 中OLR的重要性 called an Oracle Local Registry (OLR): each node in a cluster has a ...
- 第11讲- Android中进程及其优先级
第11讲Android中进程及其优先级 进程与线程: 进程:操作系统结构的基础,资源分配的最小单元,一个操作系统包括多个进程: 线程:线程存在于进程当中,是操作系统调试执行的最小单元,一个进程包括多个 ...
- Android菜鸟的成长笔记(11)——Android中的事件处理
原文:[置顶] Android菜鸟的成长笔记(11)——Android中的事件处理 Android提供了两种方式来处理事件,一个是基于回调的事件处理,另一个是基于监听的事件处理,举个例子: 基于回调的 ...
随机推荐
- Qt 开发程序后的公布问题
Qt 开发程序后的公布问题 Qt 是一套跨平台 C++ 图形用户界面应用程序开发框架,利用它能够很方便的开发各种类型的应用程序.可是随着 Qt 的发展.功能越来越强大,公布时须要文件也越来越多.公布时 ...
- Python:SMOTE算法——样本不均衡时候生成新样本的算法
Python:SMOTE算法 直接用python的库, imbalanced-learn imbalanced-learn is a python package offering a number ...
- codeforces 920 EFG 题解合集 ( Educational Codeforces Round 37 )
E. Connected Components? time limit per test 2 seconds memory limit per test 256 megabytes input sta ...
- LuoguP4246 [SHOI2008]堵塞的交通
https://zybuluo.com/ysner/note/1125078 题面 给一个网格,每次把相邻两点连通性改为\(1\)或\(0\),询问两点是否联通. 解析 线段树神题... 码量巨大,细 ...
- Luogu3403跳楼机
https://zybuluo.com/ysner/note/1099616 题面 给你三个数\(x\),\(y\),\(z\),问你能够凑出多少个[1,\(h\)]之间的数. 解析 处理出\(y\) ...
- webrtc学习资源
http://www.imaotao.cn/project/webrtc-201604
- JSP-Runoob:JSP 隐式对象
ylbtech-JSP-Runoob:JSP 隐式对象 1.返回顶部 1. JSP 隐式对象 JSP隐式对象是JSP容器为每个页面提供的Java对象,开发者可以直接使用它们而不用显式声明.JSP隐式对 ...
- MSP430 使用时 RST引脚一定拉高
因为这次省去了RESET按键,RST没做任何处理,程序下载完之后插上电池无法运行,最终原因:RST引脚没有拉高.呼呼切记啊
- hdu1814Peaceful Commission(2-SAT)
Peaceful Commission Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ...
- 这里有最全的C/C++入门到进阶书籍推荐,你需要嘛?
编程是操作性很强的一门知识,看书少不了,但只有学习和实践相结合才能起到很好的效果,一种学习方法是看视频->看书->研究书中例子->自己做些东西->交流->看书. 研究经典 ...