- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构(广度和深度优先遍历)
#include stdio.h
#include stdlib.h
#include string.h
typedef struct GNode
{
int weight;
int nIndex;
struct GNode *next;
} * GList;
struct GArray
{
char name[5];
GList next;
};
typedef struct QNode
{
GArray * data;
QNode * next;
}QNode, *QueuePtr;
typedef struct
{
QueuePtr front;
QueuePtr rear;
}LinkQueue;
bool InitQueue(LinkQueue Q)
{
Q.front = Q.rear = (QueuePtr)malloc(sizeof(QNode));
if(!Q.rear)
exit(0);
Q.front-next = NULL;
return true;
}
void DestroyQueue(LinkQueue Q)
{
while(Q.front)
{
Q.rear = Q.front-next;
free(Q.front);
Q.front = Q.rear;
}
}
bool EmptyQueue(LinkQueue Q)
{
if(Q.front == Q.rear)
return true;
else
return false;
}
bool EnQueue(LinkQueue Q, GArray * gl)
{
QueuePtr p;
p = (QueuePtr)malloc(sizeof(QNode));
if(!p)
exit(0);
p-data = gl;
p-next = NULL;
Q.rear-next = p;
Q.rear = p;
return true;
}
bool DeQueue(LinkQueue Q, GArray *gl)
{
if(Q.front == Q.rear)
return false;
QueuePtr p;
p = Q.front-next;
gl = p-data;
Q.front-next = p-next;
if(Q.rear == p)
Q.rear = Q.front;
free(p);
return true;
}
void CreateG(GArray *GArr, int **arr, int n)
{
for(int i = 0; i n; i++)
{
GArr[i].next = NULL;
char S[20];
if(i / 10 == 0)
{
S[0] = v;
S[1] = i + 0 + 1;
S[2] = \0;
}
else
{
S[0] = v;
S[1] = i / 10 + 1;
S[2] = i % 10 + 1 + 0;
}
// 顶点信息
strcpy(GArr[i].name, S);
for(int j = 0; j n; j++)
{
if(arr[i][j] != 0)
{
GList p;
p = (GList)malloc(sizeof(GNode));
p-weight = arr[i][j];
p-nIndex = j;
p-next = GArr[i].next;
GArr[i].next = p;
}
}
}
}
void BFSTree(GArray *GArr, int n)
{
bool * Visited;
Visited = (bool *)malloc(n * sizeof(bool));
if(!Visited)
exit(0);
for(int i = 0; i n; i++)
Visited[i] = false;
LinkQueue Q;
InitQueue(Q); // 初始化队列
for(int i = 0; i n; i++)
{
if(!Visited[i])
{
Visited[i] = true;
printf(%s , GArr[i].name);
EnQueue(Q, GArr[i]);
// 数据节点进队列
while(!EmptyQueue(Q))
{
GArray *pG;
您可能关注的文档
最近下载
- (高清版)-B-T 34590.10-2022 道路车辆 功能安全 第10部分:指南.pdf VIP
- ISO15189新版标准考试试题含答案.docx VIP
- 二硫化钼滚动涂覆工艺研究.docx VIP
- 利用ICP刻蚀二氧化硅的方法.pdf VIP
- 《水利电力部电力规划设计院 电力勘测设计制图统一规定 (建筑部分) SDGJ42-84》水利电力教育文献.pdf VIP
- 缠中说禅108课重点.pdf VIP
- 2021版《中华人民共和国安全生产法》培训考试题库 含答案含详细解析.pdf VIP
- 拟上市公司内控项目建议书.pptx VIP
- 三级园林绿化工(高级)技能鉴定考试题库(含答案).pdf VIP
- 07CJ03-1轻钢龙骨石膏板隔墙、吊顶.pdf VIP
文档评论(0)