数据结构实验任务七:基于广度优先搜索的六度空间理论验证

问题描述

“六度空间”理论又称作“六度分隔(Six Degrees of Separation)”理论。这个理论 可以通俗地阐述为:“你和任何一个陌生人之间所间隔的人不会超过六个,也就是 说,最多通过五个人你就能够认识任何一个陌生人。”假如给你一个社交网络图, 请你对每个节点计算符合“六度空间”理论的结点占结点总数的百分比。 输入要求 多组数据,每组数据 m+1 行。第一行有两个数字 n 和 m,代表有 n 个人和 m 组朋友关系。n 个人的编号为 1 到 n。第二行到第 m+1 行每行包括两个数字 a 和 b,代表这两个人互相认识。当 n 和 m 都等于 0 时,输入结束。 输出要求 每组数据输出 n 行,对每个结点输出与该结点距离不超过 6 的结点数占结点 总数的百分比,精确到小数点后 2 位。每个结节点输出一行,格式为“结点编号:(空 格)百分比%”

运行结果:

代码实现:

#include <stdio.h>
#include <stdlib.h>
#define MaxS 20
#define MaxE 5
//结构体部分
typedef struct{						//图结构体定义 char vex[MaxS];					//顶点数组 int vexnum;						//顶点个数 int mat[MaxS][MaxS];			//邻接矩阵 int arcnum;						//边数 
}Graph;
typedef struct{int head,tail;int mat[20];						//队列数组 
}Queue;
//全局变量部分
float result[MaxE][MaxS];					//结果存储函数
int cunt;							//用于全局变量遍历 
int state[MaxS];
//函数声明部分
void Init(Graph *a);
int Read(Graph *a);
void Cal(Graph *a);
void show();
float BFS(Graph *a,int s);
void InitQ(Queue *q);				//初始化队列 
void push(Queue* q,int n);			//入队 
int pop(Queue *q);					//出队 
//函数定义部分
void InitQ(Queue *q){q->head=0;q->tail=0;
}
void push(Queue* q,int n){q->mat[q->tail] = n;q->tail++;
}
int pop(Queue* q){q->head++;if(q->head>q->tail)return -1;return q->mat[q->head-1];
}
float BFS(Graph *a,int s){int tmp,rs=0;int *len=(int*)malloc(sizeof(int)*a->vexnum+1);			//记录到s的距离 for(int i=0;i<=a->vexnum;i++){state[i] = 0;len[i] = 0;}Queue* q = (Queue*)malloc(sizeof(Queue));InitQ(q);push(q,s);state[s]=1;for(int i = 0;i<a->vexnum;i++){						//总共遍历a->vexnum次tmp = pop(q);if(tmp==-1)continue;for(int j=1;j<=a->vexnum;j++){					//每次扫描vexnum个数  if(a->mat[tmp][j]==1&&state[j]==0){len[j] = len[tmp]+1;state[j] = 1;							//状态变成已访问push(q,j);continue;}}}for(int i=1;i<=a->vexnum;i++){if(len[i]<=6&&len[i]!=0)rs+=1;}for(int i=1;i<=a->vexnum;i++){}free(len);free(q);return (float)(rs+1)/a->vexnum*100;
}
void show(){printf("\n                  =================|    -FZC-    |===============                 \n\n");									printf("FOLLOWING OUTPUT:\n");for(int i=0;i<cunt;i++){printf("[EXP %d ]\n",i+1);for(int j=1;j<MaxS;j++){if(result[i][j]==-1)break;printf("%d: %.2f%%\n",j,result[i][j]);}}
} 
void Init(Graph *a){a->arcnum=0;a->vexnum=0;for(int i=0;i<MaxS;i++){a->vex[i] =0;state[i] = 0;result[cunt][i] = -1;for(int j=0;j<MaxS;j++){a->mat[i][j] = 0;}}}int Read(Graph *a){int n,m,s,e;printf("input n,m:");scanf("%d %d",&n,&m);if(n==0&&m==0)return 1;			//若均为0则返回1 a->vexnum = n;a->arcnum = m;printf("input relationship:\n");for(int i=0;i<m;i++){scanf("%d %d",&s,&e);a->mat[s][e] = 1;a->mat[e][s] = 1; }printf("边输入完成;共%d条\n",a->arcnum);return 0; 
}
void Cal(Graph *a){for(int i=1;i<=a->vexnum;i++){result[cunt][i] = BFS(a,i);}printf("\nSuccess!\n");cunt++; 
}
//主函数部分 
int main(){int flag = 0; Graph* a=(Graph*)malloc(sizeof(Graph));cunt=0;printf("多组数据,每组数据 m+1 行。第一行有两个数字 n 和 m,代表有 n 个人和m 组朋友关系。\nn 个人的编号为 1 到 n。\n第二行到第 m+1 行每行包括两个数字 a和 b,代表这两个人互相认识。\n当 n 和 m 都等于 0 时,输入结束。");while(1){//初始化Init(a);printf("\n                  =================|    -FZC-    |===============                 \n\n");//读取数据flag = Read(a);if(flag==1){show();				//输出结果break; }//处理数据Cal(a); }printf("程序结束!\n"); return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/255928.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

解决:AttributeError: module ‘copy’ has no attribute ‘copy’

解决&#xff1a;AttributeError: module ‘copy’ has no attribute ‘copy’ 文章目录 解决&#xff1a;AttributeError: module copy has no attribute copy背景报错问题报错翻译报错位置代码报错原因解决方法方法一方法二方法三今天的分享就到此结束了 背景 在使用之前的代…

谷歌正式发布最强 AI 模型 Gemini

2023年12月6日&#xff0c;谷歌公司宣布推出其被认为是规模最大、功能最强大的人工智能模型 Gemini。 Gemini将分为三个不同的套件&#xff1a;Gemini Ultra、Gemini Pro和Gemini Nano。 Gemini Ultra被认为具备最强大的能力&#xff0c;Gemini Pro则可扩展至多任务&#x…

RTL编码(2)——模块优化

一、顶层模块的划分 在RTL编码中&#xff0c;我们是以模块为单位进行设计的&#xff0c;模块之间的连接和嵌套关系对于电路结构有着很大的影响。一个好的系统设计中&#xff0c;我们应该使得模块尽量满足以下两个标准&#xff1a; 顶层模块扁平化内部模块层次化 1.1 顶层模块扁…

Python+requests+unittest+excel实现接口自动化测试框架

在刚刚进入测试行业的时候&#xff0c;最开始也是做功能测试&#xff0c;我想很多伙伴和我一样&#xff0c;觉得自动化测试都很高端&#xff0c;很神秘。迫不及待的想去学习作自动化测试。 以前比较常用数据库python做自动化&#xff0c;后面发现excel个人觉得更加适合&#x…

22 查找众数及中位数

题目描述 众数是指一组数据中出现次数量多的那个数&#xff0c;众数可以是多个。 中位数9是指把一组数据从小到大排列&#xff0c;最中间的那个数&#xff0c;如果这组数据的个数是奇数&#xff0c;那最中间那个就是中位数&#xff0c;如果这组数据的个数为偶数&#xff0c;那就…

Jest与typescript单元测试

文章目录 前言安装配置.vscode/launch.jsonjest.config.tsts.config.ts 测试例子 前言 简单记录一下vscode里跑Jest单元测试。 安装 yarn add -D ts-jest ts-node types/jest jest 配置 .vscode/launch.json {"version": "0.2.0","configurations…

【文件上传系列】No.0 利用 FormData 实现文件上传、监控网路速度和上传进度(原生前端,Koa 后端)

利用 FormData 实现文件上传 基础功能&#xff1a;上传文件 演示如下&#xff1a; 概括流程&#xff1a; 前端&#xff1a;把文件数据获取并 append 到 FormData 对象中后端&#xff1a;通过 ctx.request.files 对象拿到二进制数据&#xff0c;获得 node 暂存的文件路径 前端…

docker网络【重点】

一、网络知识 1、桥接模式&#xff1a;用于链接两个不同网络段的设备&#xff0c;是共享通信的一种方式 2、桥接设备&#xff1a;工作在OSI模型的第二层&#xff08;数据链路层&#xff09;。根据MAC地址转发数据帧&#xff0c;类似于交换机&#xff0c;只能转发同一网段&…

C++11:lambda表达式(对各个参数详细说明+注意事项+使用案例+探究底层)

目录 一、lambda表达式语法 1.lambda表达式书写格式 2. lambda表达式各部分说明 3.捕获列表说明 二、lambda表达式的一些使用案列 1.借助auto将lambda表达式赋值给一个变量来直接调用。 2.对于类似于sort对自定义类型排序等情况时使用lambda可简化代码 以前我们对自定义…

【SpringBoot】yml配置文件注释中文乱码

错误展示 搭了一个环境&#xff0c;一启动项目&#xff0c;yml文件中文全乱码了 解决措施 按如图顺序操作 结果 再次启动项目&#xff0c;乱码已解决&#xff01;

Spring IoC和DI

目录 一. Spring是什么 IoC DI 二. IoC&DI的使用 IoC 1.Controller&#xff08;控制器存储&#xff09; 2.Service&#xff08;服务存储&#xff09; 3.Repository&#xff08;仓库存储&#xff09; 4.Componemt&#xff08;组件存储&#xff09; 5.Configuratio…

JavaSE基础50题:8. 获取一个数二进制序列中所有的偶数和奇数位,分别输出二进制序列。

概述 获取一个数二进制序列中所有的偶数和奇数位&#xff0c;分别输出二进制序列。 如&#xff1a;从右往左数 0111&#xff08;如图&#xff09; 偶数位&#xff1a;01 奇数位&#xff1a;11 代码 public static void main(String[] args) {Scanner scanner new Scanner(Sys…