05-3. 六度空间 (30)
05-3. 六度空间 (30)
“六度空间”理论又称作“六度分隔(Six Degrees of Separation)”理论。这个理论可以通俗地阐述为:“你和任何一个陌生人之间所间隔的人不会超过六个,也就是说,最多通过五个人你就能够认识任何一个陌生人。”如图6.4所示。
图6.4 六度空间示意图
“六度空间”理论虽然得到广泛的认同,并且正在得到越来越多的应用。但是数十年来,试图验证这个理论始终是许多社会学家努力追求的目标。然而由于历史的原因,这样的研究具有太大的局限性和困难。随着当代人的联络主要依赖于电话、短信、微信以及因特网上即时通信等工具,能够体现社交网络关系的一手数据已经逐渐使得“六度空间”理论的验证成为可能。
假如给你一个社交网络图,请你对每个节点计算符合“六度空间”理论的结点占结点总数的百分比。
输入格式说明:
输入第1行给出两个正整数,分别表示社交网络图的结点数N (1<N<=104,表示人数)、边数M(<=33*N,表示社交关系数)。随后的M行对应M条边,每行给出一对正整数,分别是该条边直接连通的两个结点的编号(节点从1到N编号)。
输出格式说明:
对每个结点输出与该结点距离不超过6的结点数占结点总数的百分比,精确到小数点后2位。每个结节点输出一行,格式为“结点编号:(空格)百分比%”。
样例输入与输出:
序号 | 输入 | 输出 |
1 |
10 9 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 |
1: 70.00% 2: 80.00% 3: 90.00% 4: 100.00% 5: 100.00% 6: 100.00% 7: 100.00% 8: 90.00% 9: 80.00% 10: 70.00% |
2 |
10 8 1 2 2 3 3 4 4 5 5 6 6 7 7 8 9 10 |
1: 70.00% 2: 80.00% 3: 80.00% 4: 80.00% 5: 80.00% 6: 80.00% 7: 80.00% 8: 70.00% 9: 20.00% 10: 20.00% |
3 |
11 10 1 2 1 3 1 4 4 5 6 5 6 7 6 8 8 9 8 10 10 11 |
1: 100.00% 2: 90.91% 3: 90.91% 4: 100.00% 5: 100.00% 6: 100.00% 7: 100.00% 8: 100.00% 9: 100.00% 10: 100.00% 11: 81.82% |
4 |
2 1 1 2 |
1: 100.00% 2: 100.00% |
//陈越老师的数据结构的课程里,对这个记录层次的问题,讲的很清楚了,就是附加几个指针,不明白画画图就知道了
#include <iostream>
#include <algorithm>
#include <string>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <vector>
#include<queue>
#include<stack>
#include<map>
#include<set>
using namespace std;
#define lson rt<<1,l,MID
#define rson rt<<1|1,MID+1,r
//#define lson root<<1
//#define rson root<<1|1
#define MID ((l+r)>>1)
typedef long long ll;
typedef pair<int,int> P;
const int maxn=10005;
const int base=1000;
const int inf=999999;
const double eps=1e-5;
int n,m;
vector<int> G[maxn];
bool vis[maxn];
int bfs(int s)
{queue<int> q;q.push(s);int cnt=0;int last=s;int level=0;int tail;memset(vis,0,sizeof(vis));while(!q.empty()){int k=q.front();q.pop();for(int i=0;i<G[k].size();i++){if(!vis[G[k][i]]){vis[G[k][i]]=true;q.push(G[k][i]);tail=G[k][i];cnt++;}}if(k==last){last=tail;level++;}if(level==6){break;}}return cnt;
}int main()
{int i,j,k,t;scanf("%d%d",&n,&m);for(i=0;i<m;i++){int s,e;scanf("%d%d",&s,&e);G[s].push_back(e);G[e].push_back(s);}for(i=1;i<=n;i++)printf("%d: %.2lf%%\n",i,bfs(i)*1.0/n*100.0);return 0;
}
05-3. 六度空间 (30)相关推荐
- 7-7 六度空间 (30 分)(BFS遍历详解)(DFS最后一个点过不去)
7-7 六度空间 (30 分) 一:题目: 六度空间"理论又称作"六度分隔(Six Degrees of Separation)"理论.这个理论可以通俗地阐述为:&quo ...
- **06-图3 六度空间 (30 分)**
06-图3 六度空间 (30 分) "六度空间"理论又称作"六度分隔(Six Degrees of Separation)"理论.这个理论可以通俗地阐述为:&q ...
- 7-7 六度空间 (30分)_近30年仅6人生涯总决赛首秀得分30+ 浓眉哥能成下一个吗
在竞争激烈的总决赛上要想得到高分并不容易,一个球员在第一次站上总决赛的舞台的时候要想得到高分更不容易,即使是强如勒布朗-詹姆斯在个人NBA生涯的总决赛首秀中也只是得到14分而已.近30年NBA历史上仅 ...
- 7-7 六度空间 (30分)_现役球员中,谁最可能成下一位30000分先生?3大前十巨星没戏...
想要在NBA联盟得到3万分有多难?从联盟成立至今的70多年中,总得分超过3万分的球员一共只有7位,他们分别是贾巴尔.马龙.詹姆斯.科比.乔丹.诺维茨基和张伯伦,剩下的强如大鲨鱼.艾弗森都没能完成这一壮 ...
- 7-7 六度空间 (30 point(s))
假如给你一个社交网络图,请你对每个节点计算符合"六度空间"理论的结点占结点总数的百分比. 输入格式: 输入第1行给出两个正整数,分别表示社交网络图的结点数N(1<N≤1e3, ...
- PTA_数据结构与算法_7-7 六度空间 (30分)
"六度空间"理论又称作"六度分隔(Six Degrees of Separation)"理论.这个理论可以通俗地阐述为:"你和任何一个陌生人之间所间隔 ...
- 7-7 六度空间 (30分) 【最短路径(Floyd)】
题目描述: "六度空间"理论又称作"六度分隔(Six Degrees of Separation)"理论.这个理论可以通俗地阐述为:"你和任何一个陌生 ...
- 06-图3. 六度空间 (30)
数据有1万个,邻接矩阵挂了,所以只能套邻接表.第一次直接是套的模板,搜索过程也是参考教材指导书上的实现. #include<stdio.h> #include<string.h> ...
- 【pyhon】理想论坛爬虫1.05版,将读取和写DB分离成两个文件
下午再接再厉仿照Nodejs版的理想帖子爬虫把Python版的也改造了下,但美中不足的是完成任务的线程数量似乎停滞在100个左右,让人郁闷.原因还待查. 先把代码贴出来吧,也算个阶段性成果. 爬虫代码 ...
最新文章
- HBase应用快速学习
- C:\WINDOWS\WinSxS目录介绍,来自百度词条
- 网站刷关键词_中小企业网站排名如何做SEO优化 - 刷百度关键词排名
- vsc系统是什么意思_crm系统什么意思
- Math、Date内置对象方法整理
- Paxos算法(Basic Paxos 与 Multi-Paxos思想)
- mpvue 从零开始 女友的发带 2 window中设置
- linux下进程监控6,Linux进程监控技术—精通软件性能测试与LoadRunner最佳实战(6)...
- 64位 linux 32位连接器,32位汇编程序在64位Ubuntu上的汇编和连接
- 排序算法(1)----选择排序算法
- sprintf 详解
- xgboost分类原理
- SAP从入门到精通 知识体系
- 计算机word怎么设置页眉,Word怎么设置长文档的页眉页脚?_计算机办公软件知识...
- 传统消费将被销巴生活全返消费颠覆
- 编解码(1)之基本像素格式转换
- 【经典收藏】深度技术ghost官方原版XP系统sp3下载地址 ...
- 计算机插上u盘就无法点亮,u盘启动电脑无反应,小编教你电脑插上U盘后无法启动解决方法...
- 【Oracle Hint】Oracle Hint学习笔记【一】
- STP协议 与 STP树的生成