7-12(圖) 社交網絡圖中結點的“重要性”計算(30 分)

在社交網絡中,個人或單位(結點)之間通過某些關系(邊)聯系起來。他們受到這些關系的影響,這種影響可以理解為網絡中相互連接的結點之間蔓延的一種相互作用,可以增強也可以減弱。而結點根據其所處的位置不同,其在網絡中體現的重要性也不盡相同。

“緊密度中心性”是用來衡量一個結點到達其它結點的“快慢”的指標,即一個有較高中心性的結點比有較低中心性的結點能夠更快地(平均意義下)到達網絡中的其它結點,因而在該網絡的傳播過程中有更重要的價值。在有N個結點的網絡中,結點v?i??的“緊密度中心性”Cc(v?i??)數學上定義為v?i??到其余所有結點v?j?? (ji) 的最短距離d(v?i??,v?j??)的平均值的倒數:

對于非連通圖,所有結點的緊密度中心性都是0。

給定一個無權的無向圖以及其中的一組結點,計算這組結點中每個結點的緊密度中心性。

輸入格式:

輸入第一行給出兩個正整數N和M,其中N(10?4??)是圖中結點個數,順便假設結點從1到N編號;M(10?5??)是邊的條數。隨后的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
解析:這個題如果掌握迪杰斯特拉算法并不難,希望同學們好好看課本,
我還是變參考課本邊做的,有個難點就是,你如果想偷懶,靜態分配一個
a【n】【n】的數組,那么肯定會數組太大直接崩掉,所以動態分配就好了,
(希望僅供參考,不要直接復制到作業)
代碼:
#include<iostream>
#include<cstring>
#include<string>
#include<bits/stdc++.h>
#include<cstdio>
#include<cmath>
#define maxn 10001
using namespace std;
int n,m;
int d[maxn],visit[maxn];
int Dijkstra(int *a[],int v){for(int i=1;i<=n;i++){visit[i]=0;d[i]=a[v][i];}visit[v]=1;d[v]=0;int sum=0;int x;for(int k=1;k<=n;k++){int min=maxn;for(int w=1;w<=n;w++)if(!visit[w]&&d[w]<min){x=w;min=d[w];}visit[x]=1;for(int w=1;w<=n;w++){if(!visit[w]&&d[x]+a[x][w]<d[w]){d[w]=d[x]+a[x][w];}}}for(int i=1;i<=n;i++){if(d[i]==maxn)return -1;sum+=d[i];//cout<<"@@@@@@@@@"<<d[i]<<endl;
    }return sum;
}int main(){
int x,y;
scanf("%d%d",&n,&m);
int **a=(int**)malloc(sizeof(int*)*(n+1));for(int i=1; i<=n; i++) {a[i]=(int*)malloc(sizeof(int)*(n+1));}for(int i=1;i<=n;i++){d[i]=maxn;for(int j=1;j<=n;j++){a[i][j]=maxn;}
}//輸入
for(int i=1;i<=m;i++){cin>>x>>y;a[x][y]=a[y][x]=1;
}
int k;
cin>>k;int v;
for(int i=0;i<k;i++){cin>>v;int su=  Dijkstra(a,v);if(su==-1) printf("Cc(%d)=%.2lf\n",v,0.00);elseprintf("Cc(%d)=%.2lf\n",v,(n-1)*1.0/su*1.0);
}return 0;}

?


轉載于:https://www.cnblogs.com/xuyibao/p/8035913.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/370222.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/370222.shtml
英文地址,請注明出處:http://en.pswp.cn/news/370222.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

linux系統的安裝程序,Linux系統安裝

為了不影響本機系統&#xff0c;建議在虛擬機上創建并安裝Linux系統&#xff0c;本次安裝centos7 64位的鏡像。詳細步驟如下&#xff1a;1、首先在虛擬機主頁創建新的虛擬機。... 圖1.1 2、選擇自定義安裝&#xff0c;這樣方便我們更好了解虛擬機&#xff0c;然后點擊下一步。.…

REST與Apache Camel

在Camel中公開HTTP終結點的方法有很多&#xff1a;jetty&#xff0c;tomcat&#xff0c;servlet&#xff0c;cxfrs和restlet。 其中的兩個組件– cxfrs和restlet也只需幾行代碼即可支持REST語義。 這個簡單的示例演示了如何使用camel-restlet和camel-jdbc進行CRUD操作。 四個HT…

百米路由器2登陸地址_騰達無線路由器怎么安裝,真的不錯

騰達無線路由器怎么安裝1、WAN口連接寬帶進線(即網絡公司進來的線或貓出來的線&#xff0c;一般顏色不一樣)、LAN口連接局域網內的電腦。2、設置所連接電腦的IP地址。右鍵點擊網上鄰居屬性3、右鍵點擊本地連接屬性4、選擇Internet協議TCP/IP屬性5、點擊選擇自動獲得IP地址和自動…

input點擊鏈接另一個頁面,各種操作。

1.鏈接到某頁<input type"button" name"Submit" value"確 定" class"btn" οnclick"location.hreffilename.html" />2.返回(等同后退)<input name"Submit2" type"button" class"btn"…

80. Remove Duplicates from Sorted Array II

題目描述 Follow up for “Remove Duplicates”: What if duplicates are allowed at most twice? For example, Given sorted array nums [1,1,1,2,2,3], Your function should return length 5, with the first five elements of nums being 1, 1, 2, 2 and 3. It doesn…

JavaFX 2 XYCharts和Java 7功能

我最喜歡的JavaFX 2功能之一是它在javafx.scene.chart包中提供的標準圖表。 該軟件包提供了幾種不同類型的現成圖表。 除了其中之一&#xff08; PieChart &#xff09;以外&#xff0c;所有其他都是“ 2軸圖”&#xff08; XYChart的特定實現&#xff09;。 在本文中&#xff…

前端基礎-HTML的的標簽詳解

閱讀目錄 一、head內常用標簽二、 HTML語義化三、 字符實體四、 h系列標簽五、 p標簽六、 img標簽七、 a標簽八、 列表標簽九、 table標簽十、 form標簽 一、 head內常用標簽 1、meta相關 #1、指定字符集<meta charset"gbk">#2、頁面描述<meta name"…

new失敗跟蹤函數_WinDbg預覽時間線:調試器中的時間線可以允許用戶記錄跟蹤

時間旅行調試(TTD)允許用戶記錄跟蹤&#xff0c;這些跟蹤是對程序執行的記錄。時間線是執行過程中發生的事件的直觀表示&#xff0c;這些事件可以是包括斷點&#xff0c;內存讀/寫&#xff0c;函數調用和返回以及異常。使用時間線窗口可以快速查看重要事件&#xff0c;了解相對…

linux 進程的執行時間,Linux 獲取進程執行時間

Linux 獲取進程執行時間1 前言測試一個程序的執行時間, 時間包括用戶 CPU 時間系統 CPU 時間時鐘時間之前獲取之前時間都是在程序的 main 函數用 time 函數實現, 這個只能粗略的計算程序的執行時間, 不能準確的獲取其他時間在看 APUE 時, 書中有關程序時間測試程序, 非常正規, …

Java環境變量的設置

1.計算機->屬性->高級系統設置->環境變量 2.設置JAVA_HOME和path&#xff0c;1.5之后的JDK可以不設置classpath 3.JAVA_HOME的路徑是JDK的安裝路徑 4.在系統變量里面找到path&#xff0c;然后點擊修改&#xff0c;在最后面添加%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin; 5…

merge

merge語句具有按條件獲取要更新或插入到表中的數據行&#xff0c;然后從1個或多個源頭對表進行更新或向表中插入行兩方面的能力。經常用在數據倉庫中移動大量數據。 語法: merge<hint> into<table_name> using<table_view_or_query> on<condition> whe…

可以優化同步嗎?

總覽 有一個常見的誤解&#xff0c;因為JIT很智能&#xff0c;并且可以消除對象的同步&#xff0c;而該對象僅存在于不影響性能的方法中。 比較StringBuffer和StringBuilder的測試 這兩個類基本上做相同的事情&#xff0c;除了一個是同步的&#xff08;StringBuffer&#xff0…

perl exe執行提示缺少文件解決方法

在項目開發中&#xff0c;使用perl語言編譯的exe可執行文件;在項目中使用了XML::LibXML模塊&#xff1b;發現exe在本機電腦執行正常&#xff0c;但在其他同事執行時卻提示缺少libxml2-2.dll等文件。 問題現象&#xff1a; 無法啟動此程序&#xff0c;因為計算機中丟失libxml2-2…

華為搶購助手_華為榮耀20系列手機采用的五項新科技,科普簡介

5月底榮耀20系列在上海發布&#xff0c;榮耀20系列旗艦手機擁有五項榮耀自主研發的新科技&#xff0c;包括LinkTurbo網絡聚合加速、超級NFC、方舟編譯器、人性化YOYO智慧生命體&#xff0c;超級藍牙。下面分別介紹一下這五項新科技。LinkTurbo網絡聚合加速先來科普一下LinkTurb…

Flex彈性布局

1 Flex: 彈性布局 (轉) 任何一個容器都可以指定為 Flex 布局。 1 .box {2  display: flex;3 } 行內元素也可以使用 Flex 布局。 1 .box{2 display: inline-flex;3 } 注意&#xff0c;設為 Flex 布局以后&#xff0c;子元素的 float、 clear 和 vertical-align 屬性將失效…

洛谷P3045 [USACO12FEB]牛券Cow Coupons

P3045 [USACO12FEB]牛券Cow Coupons 71通過248提交題目提供者洛谷OnlineJudge標簽USACO2012云端難度提高/省選-時空限制1s / 128MB提交 討論 題解 最新討論更多討論 86分求救題目描述 Farmer John needs new cows! There are N cows for sale (1 < N < 50,000), and …

python數據挖掘電影評分分析_Pyhon數據分析項目——男女電影評分差異比較

《用Python玩轉數據》數據分析項目一、程序功能基于MovieLens100k數據集中男性女性對電影的評分來判斷男性還是女性電影評分的差異性更大。二、數據來源數據集下載&#xff1a;http://files.grouplens.org/datasets/movielens/ml-100k.zip數據含義&#xff1a;u.data表示100k條…

發掘Apache Camel的力量

最近幾年&#xff0c;ESB軟件越來越受歡迎。 如果大多數人通常知道什么是ESB&#xff0c;那么他們很少會清楚地了解這種體系結構的不同組件的確切作用。 例如&#xff0c;Apache ServiceMix由三個主要組件組成&#xff1a;Apache Karaf&#xff08;OSGI容器&#xff09;&#…

unix/linux系統中文件分為哪些類型?,到底該如何理解 Unix/Linux 的文件系統?看這篇就知道了...

原標題&#xff1a;到底該如何理解 Unix/Linux 的文件系統&#xff1f;看這篇就知道了作者&#xff1a;舠

【Luogu】P1131時態同步(樹形DP)

題目鏈接 甚矣吾衰也&#xff01;這么簡單的DP我都不會了 太恐怖了 樹形DP&#xff0c;從子樹里選出時間最長的來&#xff0c;剩下的調到這個最長時間即可。 #include<cstdio> #include<cctype> #include<algorithm> #include<cstring>using std::max;…