社交网络图中结点的“重要性”计算 (30 分) C++解法
社交网络图中结点的“重要性”计算 (30 分)
在社交网络中,个人或单位(结点)之间通过某些关系(边)联系起来。他们受到这些关系的影响,这种影响可以理解为网络中相互连接的结点之间蔓延的一种相互作用,可以增强也可以减弱。而结点根据其所处的位置不同,其在网络中体现的重要性也不尽相同。
“紧密度中心性”是用来衡量一个结点到达其它结点的“快慢”的指标,即一个有较高中心性的结点比有较低中心性的结点能够更快地(平均意义下)到达网络中的其它结点,因而在该网络的传播过程中有更重要的价值。在有N个结点的网络中,结点vi 的“紧密度中心性”Cc(vi )数学上定义为vi  到其余所有结点vj (j≠i) 的最短距离d(vi ,vj )的平均值的倒数:
对于非连通图,所有结点的紧密度中心性都是0。
给定一个无权的无向图以及其中的一组结点,计算这组结点中每个结点的紧密度中心性。
输入格式:
输入第一行给出两个正整数N和M,其中N(≤104 )是图中结点个数,顺便假设结点从1到N编号;M(≤105 )是边的条数。随后的M行中,每行给出一条边的信息,即该边连接的两个结点编号,中间用空格分隔。最后一行给出需要计算紧密度中心性的这组结点的个数K(≤100)以及K个结点编号,用空格分隔。
输出格式:
按照Cc(i)=x.xx的格式输出K个给定结点的紧密度中心性,每个输出占一行,结果保留到小数点后2位。
输入样例:
9 14
1 2
1 3
1 4
2 3
3 4
4 5
4 6
5 6
5 7
5 8
6 7
6 8
7 8
7 9
3 3 4 9
输出样例:
Cc(3)=0.47
Cc(4)=0.62
Cc(9)=0.35
代码:
#include <iostream>
#include <queue>
#include <climits>
#include <map>
using namespace std;
class Graph {
public:
    Graph(int v, int e) : Vertex(v), Edge(e) {
        G = new int *[v];
        for (int i = 0; i < v; i++) {
            G[i] = new int[v];
            for (int j = 0; j < v; j++) {
                G[i][j] = 0;
            }
        }
    }
    ~Graph(){
        for (int i = 0; i < Vertex; i++) {
            delete[] G[i];
        }
        delete[] G;
    }
    void Insert(int v1, int v2) {
        G[v1][v2] = 1;
        G[v2][v1] = 1;
    }
    double Importance(int v) {
        int distance[Vertex];
        for (int i = 0; i < Vertex; i++) {
            distance[i] = INT_MAX;
        }
        distance[v] = 0;
        int Visited[Vertex][Vertex];
        for (int i = 0; i < Vertex; i++) {
            for (int j = 0; j < Vertex; j++) {
                Visited[i][j] = 0;
            }
        }
        map<int,int> visitedNode;
        queue<int> q;
        q.push(v);
        while (!q.empty()) {
            int temp = q.front();
            q.pop();
            for (int i = 0; i < Vertex; i++) {
                if (G[temp][i] == 1 && Visited[temp][i] == 0 && visitedNode[i]==0) {
                    if (distance[i] > distance[temp] + 1)
                        distance[i] = distance[temp] + 1;
                    visitedNode[i]=1;
                    q.push(i);
                    Visited[temp][i] = 1;
                    Visited[i][temp] = 1;
                }
            }
        }
        double sum = 0;
        for (int i = 0; i < Vertex; i++) {
            sum += distance[i];
        }
        return (Vertex - 1.0) / sum;
    }
private:
    int Vertex;
    int Edge;
    int **G;
};
int main() {
    int vertex, edge;
    scanf("%d %d", &vertex, &edge);
    Graph graph(vertex, edge);
    int temp1, temp2;
    for (int i = 0; i < edge; i++) {
        scanf("%d %d", &temp1, &temp2);
        graph.Insert(temp1 - 1, temp2 - 1);
    }
    int num;
    scanf("%d", &num);
    int n;
    for (int i = 0; i < num; i++) {
        scanf("%d", &n);
        printf("Cc(%d)=%.2f\n", n, graph.Importance(n - 1));
    }
}
社交网络图中结点的“重要性”计算 (30 分) C++解法的更多相关文章
- PTA数据结构与算法题目集(中文)  7-36 社交网络图中结点的“重要性”计算 (30 分)
		PTA数据结构与算法题目集(中文) 7-36 社交网络图中结点的“重要性”计算 (30 分) 7-36 社交网络图中结点的“重要性”计算 (30 分) 在社交网络中,个人或单位(结点)之间通过某 ... 
- PTA 社交网络图中结点的“重要性”计算(30 分)
		7-12 社交网络图中结点的“重要性”计算(30 分) 在社交网络中,个人或单位(结点)之间通过某些关系(边)联系起来.他们受到这些关系的影响,这种影响可以理解为网络中相互连接的结点之间蔓延的一种相互 ... 
- 7-10 社交网络图中结点的“重要性”计算(30 point(s)) 【并查集+BFS】
		7-10 社交网络图中结点的"重要性"计算(30 point(s)) 在社交网络中,个人或单位(结点)之间通过某些关系(边)联系起来.他们受到这些关系的影响,这种影响可以理解为网络 ... 
- PTA 7-12(图) 社交网络图中结点的“重要性”计算 最短路
		7-12(图) 社交网络图中结点的“重要性”计算 (30 分) 在社交网络中,个人或单位(结点)之间通过某些关系(边)联系起来.他们受到这些关系的影响,这种影响可以理解为网络中相互连接的结点之间蔓延的 ... 
- 7-11 社交网络图中结点的“重要性”计算 (30 分)(Dijkstra算法)
		题意: 思路:对每个输入的点跑一遍dijkstra算法,然后对这个点到所有点的距离求和按公式输出就可以了. (这次尝试了用数组模拟链表来做最短路问题,刷新了自己对最短路的理解) 这里构造链表的过程我 ... 
- Excel中最精确的计算年龄的公式
		身份证算年龄 假设A1是身份证号所在单元格 =IF(MONTH(NOW())<INT(MID(A1,11,2)),INT(YEAR(NOW())-INT(MID(A1,7,4)))-1,IF(M ... 
- sql server2005版本中,len函数计算了字符串末尾的空格
		sql server2005版本中,len函数计算了字符串末尾的空格的长度,以下是测试脚本: print @@version declare @v varchar(max) set @v = 'hp, ... 
- dgraph解决社交关系中的正反向查找
		dgraph解决社交关系中的正反向查找 本篇介绍的是, 社交关系中的关注者与被关注者在dgraph中如何实现查找. 对dgraph的基本操作不太清楚的可以看看我之前写的博客 dgraph实现基本操作 ... 
- jQuery中height()不能精确计算的问题
		jQuery中关于高度的计算有三个方法:outerHeight().innerHeight().height() outerHeight():获取元素集合中第一个元素的当前计算高度值,包括paddin ... 
随机推荐
- Android使用sqlite数据库的使用
			移动端Android开发,我们使用的是sqlite数据库,这是一个轻量级的数据库,我们在使用的时候,甚至不想mysql等数据库一样加载驱动啊,在androidsdk中,都已经帮我们做好了,我们只需要用 ... 
- Restful WebService简介
			RESTful Web Services已经渐渐開始流行, 主要是用于解决异构系统之间的通信问题.非常多站点和应用提供的API,都是基于RESTful风格的Web Services,比較就有Googl ... 
- 大数据R语言简析
			R语言是用于统计分析.画图的语言和操作环境.R是属于GNU系统的一个自由.免费.源码开放的软件.它是一个用于统计计算和统计制图的优秀工具. R是统计领域广泛使用的诞生于1980年左右的S语言的一个分支 ... 
- 稀疏表示  Sparse Representation
			稀疏表示_百度百科 https://baike.baidu.com/item/%E7%A8%80%E7%96%8F%E8%A1%A8%E7%A4%BA/16530498 信号稀疏表示是过去近20年来信 ... 
- Struts数据验证
			Action类继承了ActionSupport类,而该类实现了Action.Validateable.ValidationAware.TextProvider.LocaleProvider和Seria ... 
- YTU 2506: 切面条
			2506: 切面条 时间限制: 1 Sec 内存限制: 128 MB 提交: 382 解决: 223 题目描述 一根高筋拉面,中间切一刀,可以得到2根面条. 如果先对折1次,中间切一刀, ... 
- 洛谷 P2678 [ NOIP 2015 ] 跳石头 —— 二分答案
			题目:https://www.luogu.org/problemnew/show/P2678 二分答案. 代码如下: #include<iostream> #include<cstd ... 
- 2-6 ES6常用语法
- Java DOM方式解析XML(模板)
			//创建一个DocumentBuilderFactory工厂实例 DocumentBuilderFactory DBF=DocumentBuilderFactory.newInstance(); // ... 
- Golang 入门 : 竞争条件
			笔者在前文<Golang 入门 : 理解并发与并行>和<Golang 入门 : goroutine(协程)>中介绍了 Golang 对并发的原生支持以及 goroutine 的 ... 
