六度空间(MOOC)
输入格式:
输出格式:
输入样例:
输出样例:
思路:图的遍历,此题因为是寻找距离数不超过6的结点,相当于寻找层数<6的结点。采用BFS,同时改造BFS返回一个节点数count。
遍历过程中,采用传统的BFS,建立队列,同时写出while循环结构。由于寻找层数<6的节点数,建立变量,节点数count,层数level,同时记录
每一层最后一个结点last。当(level==6)跳出循环,返回结果。
接下来解决获得last的方法:在每次入队的同时,记录tail=入队的结点。
当记录下来的入队的结点tail和v相等时,last=tail,即将last更新为当层的最后一个结点,同时level++。
注意:1.输出的结果为小数,用printf中的%.02f输出结果。同时要将结果从int型转换为double型。
2.每次输出一个结点的所占比百分数后,清空vis数组的标记。
#include<cstdio>
#include<queue>
#include<cstring>
using namespace std; int n,m;
int G[][];
int vis[];
int BFS(int v){
vis[v]=;
queue<int> q;
q.push(v);
int count=;
//level 和last用于解决判断层数的问题 level记录层数,last记录当前结点访问的最后一个数
//问题是我们如何更新last,使得成为最后一个结点。
//这里使用tail记录出队的结点,如果当前弹出的v==last,tail指向的结点一定是下一层的最后一个结点
int level=,last=v,tail;
while(!q.empty()){
int v=q.front();
q.pop();
for(int i=;i<=n;i++){ //这个地方不是int i=0;i<n 注意!
if(!vis[i]&&G[v][i]>){
vis[i]=;
q.push(i);
count++;
tail=i;
}
}
if(v==last){
level++;last=tail;
}
if(level==)break;
}
return count;
}
int main(){
scanf("%d %d",&n,&m);
int x,y;
for(int i=;i<m;i++){
scanf("%d %d",&x,&y);
getchar();
G[x][y]=G[y][x]=;
}
for(int i=;i<=n;i++){
printf("%d: ",i);
int count=BFS(i);
//一定要强制转换
double res=(double)count/(double)n*;
printf("%.2lf",res);
printf("%\n");
memset(vis,,sizeof(vis));
}
}
六度空间(MOOC)的更多相关文章
- 【MOOC课程学习记录】数据结构
看了中国大学MOOC zju的<数据结构>2019夏的第九次开课.做了一些PTA上的习题,没有全做,因为做得慢,老是不会,加上并不能做到一有空就学习,所以做不完了,给跪了Orz. 以后有时 ...
- 数据结构 浙大MOOC 笔记二 线性结构
线性表及其表现 第二章的内容是关于三种最基本的数据结构 结合<DDSA>第三章 表.栈和队列做一个总结 首先简单说明一下各个数据结构的特点: 数组:连续存储,遍历快且方便,长度固定,缺点是 ...
- 数据结构-浙大 MOOC 笔记一 基本概念
做一些笔记记录自己的学习过程 第一节课介绍了数据结构的基本概念,首先没有直接给出相关的定义而是通过思考如何在书架上摆放书籍这样一个简单的类比了解到数据的组织方式的重要性,并通过printN函数的循环实 ...
- 关于MOOC的学习总结
20125133 马国祥 原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 对 ...
- 我的首个MOOC课程《面向对象软件开发实践》
我的首个MOOC课程<面向对象软件开发实践> 我将在网易云课堂开讲MOOC课<面向对象软件开发实践>(http://mooc.study.163.com/course/YOOK ...
- mooc
Coursera 课程来源 2014年前已与斯坦福.普林斯顿等近90所大学和教育机构达成合作关系. 用户类型 主要类别为学生.求职者.公司人.其中,求职者可在Coursera上获得<成就报告&g ...
- PTA 06-图3 六度空间 (30分)
"六度空间"理论又称作"六度分隔(Six Degrees of Separation)"理论.这个理论可以通俗地阐述为:"你和任何一个陌生人之间所间隔 ...
- MOOC即Massive Open Online Course的缩写
A man can succeed at almost anything for which he was unlimited enthusiasm. 只要有无限的热情,一个人几乎可以在任何事情上取得 ...
- 韩玉琪 《Linux内核分析》MOOC课程
http://www.cnblogs.com/hyq20135317/p/5422516.html http://mooc.study.163.com/course/USTC-1000029000
随机推荐
- SOJ4453 Excel列数 进制转换
描述 我们都知道Excel的列数是用字母表示的,比如第1列对应A,第27列对应AA. 假设给定一个正整数n,你能给出它所对应的字母表示么? 输入格式 程序需要读入多个测试样例,每个测试样例中: 一个正 ...
- 在myeclipse的工作环境上配置默认编码为UTF-8
将默认环境转为UTF-8,看图分析: 在windows->Preferences上 这样整个环境就变成UTF-8,只是这样还不够, 还须要,假设你须要所有文件都设为UTF-8,就: wa ...
- 【CF163E 】e-Government
题目 两个\(log\)的树状数组套树剖? 我们对于给出的\(n\)个模式串建立\(AC\)自动机,之后对于每一个询问串直接丢上去匹配 如果这里是暴力的话,我们直接一路跳\(fail\)累加作为结束位 ...
- Python之Flask框架使用
Flask和Django.Bottle号称Python中的强大又简单的Web框架. Flask是一个使用Python编写的轻量级Web应用框架.基于Werkzeug WSGI工具箱和Jinja2 模板 ...
- Spring源码分析(十三)缓存中获取单例bean
摘要:本文结合<Spring源码深度解析>来分析Spring 5.0.6版本的源代码.若有描述错误之处,欢迎指正. 介绍过FactoryBean的用法后,我们就可以了解bean加载的过程了 ...
- 443 C. Short Program
http://codeforces.com/contest/879/problem/C Petya learned a new programming language CALPAS. A progr ...
- HDU 1754 I Hate It(线段树之单点更新 区间最值查询)
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- 安装MySQL56时,停止在start service这一步
问题: 在安装MySQL56时,安装程序执行到start service这一步就不能完成,系统一直提示“安装时间比预期的的长,是否停止安装这一步(configuration of mysql seve ...
- Centos 模拟生成文件的脚本
#!/bin/sh count= #控制每秒写入不同大小的文件 while true do ;i<=$count;i++)) do /bin/-`.jpg done ;i<=$count; ...
- 阿里云linux服务器打开端口号
之前linux回滚了下,然后就连不上xshell和filezille了,后台安全配置哪里也都打开了端口号了,还是不行.然后我就想重启下ssh服务 ,执行service sshd restart 提示1 ...