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提供了两种方式来处理事件,一个是基于回调的事件处理,另一个是基于监听的事件处理,举个例子: 基于回调的 ...
随机推荐
- 用JavaScript截图
用JavaScript截图 使用JavaScript截图,这里我要推荐两款开源组件:一个是Canvas2Image,它可以将Canvas绘图编程PNG/JPEG/BMP的图像:但是光有它还不够,我 ...
- 设置IIS 兼容32位DLL
限Win7/Windows servser 2008 IIS的设置: 1.选择引用程序池 2.选择公布网站的.点击高级设置 3.启用32位应用程序属性改为True
- Android离线语音识别(PocketSphinx)
近期做项目.用到离线语音识别.整了好久,查了好多方法.最终完毕.网上资料有点乱,并且大部分就是那几个人写的.一群人转!以下我总结一下.也为后来人行个方便. 关于环境配置我就不多说了.我就是依照这个教程 ...
- luogu2744 量取牛奶
题目大意 给出一个整数集合$A$,总数$N$,规定一个整数序列$\{a_n\}, \forall i, a_i\in A$满足条件:存在一个正整数序列$\{k_n\}$,使得$\sum_{i=1}^n ...
- NOI.AC #31. MST
好像又是神仙dp....gan了一早上 首先这是个计数类问题,上DP, 对于一个最小生成树,按照kruskal是一个个联通块,枚举边小到大合成的 假如当前边是树边,那么转移应该还是枚举两个块然后合并 ...
- ASP.NET 4 and Visual Studio 2010
https://msdn.microsoft.com/en-us/library/ee532866.aspx The topics in this section provide informatio ...
- 【BZOJ 2160】 拉拉队排练
[题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=2160 [算法] 先简化题意 : 给定一个字符串,求最长的k个奇回文子串长度的乘积 先 ...
- js产生随机数教程
<script> function GetRandomNum(Min,Max){ var Range = Max - Min; var Rand = Math.random() ...
- [App Store Connect帮助]三、管理 App 和版本(1)添加 App 至您的帐户
在向 App Store Connect 上传您 App 的构建版本之前,您必须先在您的 App Store Connect 帐户内新建一个 App. 如果您想将 iOS App 和 Apple TV ...
- 【题解】永无乡 [HNOI2012] [BZOJ2733] [P3224]
[题解]永无乡 [HNOI2012] [BZOJ2733] [P3224] [题目描述] 永无乡包含 \(n\) 座岛,编号从 \(1\) 到 \(n\) ,每座岛都有自己的独一无二的重要度,按照重要 ...