05-3. 六度空间 (30)

时间限制
1500 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

“六度空间”理论又称作“六度分隔(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)相关推荐

  1. 7-7 六度空间 (30 分)(BFS遍历详解)(DFS最后一个点过不去)

    7-7 六度空间 (30 分) 一:题目: 六度空间"理论又称作"六度分隔(Six Degrees of Separation)"理论.这个理论可以通俗地阐述为:&quo ...

  2. **06-图3 六度空间 (30 分)**

    06-图3 六度空间 (30 分) "六度空间"理论又称作"六度分隔(Six Degrees of Separation)"理论.这个理论可以通俗地阐述为:&q ...

  3. 7-7 六度空间 (30分)_近30年仅6人生涯总决赛首秀得分30+ 浓眉哥能成下一个吗

    在竞争激烈的总决赛上要想得到高分并不容易,一个球员在第一次站上总决赛的舞台的时候要想得到高分更不容易,即使是强如勒布朗-詹姆斯在个人NBA生涯的总决赛首秀中也只是得到14分而已.近30年NBA历史上仅 ...

  4. 7-7 六度空间 (30分)_现役球员中,谁最可能成下一位30000分先生?3大前十巨星没戏...

    想要在NBA联盟得到3万分有多难?从联盟成立至今的70多年中,总得分超过3万分的球员一共只有7位,他们分别是贾巴尔.马龙.詹姆斯.科比.乔丹.诺维茨基和张伯伦,剩下的强如大鲨鱼.艾弗森都没能完成这一壮 ...

  5. 7-7 六度空间 (30 point(s))

    假如给你一个社交网络图,请你对每个节点计算符合"六度空间"理论的结点占结点总数的百分比. 输入格式: 输入第1行给出两个正整数,分别表示社交网络图的结点数N(1<N≤1e3, ...

  6. PTA_数据结构与算法_7-7 六度空间 (30分)

    "六度空间"理论又称作"六度分隔(Six Degrees of Separation)"理论.这个理论可以通俗地阐述为:"你和任何一个陌生人之间所间隔 ...

  7. 7-7 六度空间 (30分) 【最短路径(Floyd)】

    题目描述: "六度空间"理论又称作"六度分隔(Six Degrees of Separation)"理论.这个理论可以通俗地阐述为:"你和任何一个陌生 ...

  8. 06-图3. 六度空间 (30)

    数据有1万个,邻接矩阵挂了,所以只能套邻接表.第一次直接是套的模板,搜索过程也是参考教材指导书上的实现. #include<stdio.h> #include<string.h> ...

  9. 【pyhon】理想论坛爬虫1.05版,将读取和写DB分离成两个文件

    下午再接再厉仿照Nodejs版的理想帖子爬虫把Python版的也改造了下,但美中不足的是完成任务的线程数量似乎停滞在100个左右,让人郁闷.原因还待查. 先把代码贴出来吧,也算个阶段性成果. 爬虫代码 ...

最新文章

  1. HBase应用快速学习
  2. C:\WINDOWS\WinSxS目录介绍,来自百度词条
  3. 网站刷关键词_中小企业网站排名如何做SEO优化 - 刷百度关键词排名
  4. vsc系统是什么意思_crm系统什么意思
  5. Math、Date内置对象方法整理
  6. Paxos算法(Basic Paxos 与 Multi-Paxos思想)
  7. mpvue 从零开始 女友的发带 2 window中设置
  8. linux下进程监控6,Linux进程监控技术—精通软件性能测试与LoadRunner最佳实战(6)...
  9. 64位 linux 32位连接器,32位汇编程序在64位Ubuntu上的汇编和连接
  10. 排序算法(1)----选择排序算法
  11. sprintf 详解
  12. xgboost分类原理
  13. SAP从入门到精通 知识体系
  14. 计算机word怎么设置页眉,Word怎么设置长文档的页眉页脚?_计算机办公软件知识...
  15. 传统消费将被销巴生活全返消费颠覆
  16. 编解码(1)之基本像素格式转换
  17. 【经典收藏】深度技术ghost官方原版XP系统sp3下载地址 ...
  18. 计算机插上u盘就无法点亮,u盘启动电脑无反应,小编教你电脑插上U盘后无法启动解决方法...
  19. 【Oracle Hint】Oracle Hint学习笔记【一】
  20. STP协议 与 STP树的生成

热门文章

  1. 最小相位滤波器 matlab,基于MATLAB最小相位数字滤波器的设计方法研究
  2. Mysql中如何根据.frm和.idb文件恢复表结构
  3. 损失函数(Loss)
  4. Yolov3没框原因和解决办法
  5. 策略模式和工厂模式的区别
  6. 【Canvas】js用Canvas绘制阴阳太极图动画效果
  7. 代码服务流水线部署平台
  8. newifi无盘服务器,newifi 3 padavan纯净版固件,2.4G挺稳定,2019年5.09更新
  9. 微机原理-第五章 微型计算机接口和外设的数据传输
  10. UDP点对点传输实现