⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tu.txt

📁 1、 用邻接表作为存储结构创建无向图 2、 分别用深度优先和广度优先遍历无向图
💻 TXT
字号:
#define MAX 40
#include<stdlib.h>
#include<stdio.h>
#include<conio.h>
#include<string.h>


typedef struct ArCell{
int adj;
}ArCell,AdjMatrix[MAX_VERTEX_NUM][MAX_VERTEX_NUM];

typedef struct
{
char name[20];
}infotype;


typedef struct
{
infotype vexs[MAX_VERTEX_NUM];
AdjMatrix arcs;
int vexnum,arcnum;
}MGraph;
 

基本操作:
int LocateVex(MGraph *G,char* v);
MGraph * CreatUDN(MGraph *G);
int FirstAdjVex(MGraph *G,int v);
void VisitFunc(MGraph *G,int v);
int NextAdjVex(MGraph *G,int v,int w);
void DFS(MGraph *G,int v);
void DFSTraverse(MGraph *G,char *s);
int InitQueue(LinkQueue *Q);
void EnQueue(LinkQueue *Q,int a );
int DeQueue(LinkQueue *Q,int *v);
int QueueEmpty(LinkQueue *Q);
void BFSTraverse(MGraph *G,char *str);

主程序及其他伪码:
int LocateVex(MGraph *G,char* v)
{ int c=-1,i;

for(i=0;i<G->vexnum;i++)
if(strcmp(v,G->vexs[i].name)==0)
{c=i;break;}
return c;
}


MGraph * CreatUDN(MGraph *G)//初始化图,接受用户输入
{
int i,j,k,w;
char v1[20],v2[20];
printf("请输入图的顶点数,弧数:");
scanf("%d%d",&G->vexnum,&G->arcnum);
printf("结点名字:\n");
for(i=0;i<G->vexnum;i++){
printf("No.%d:",i+1);
scanf("%s",G->vexs[i].name);}
for(i=0;i<G->vexnum;i++)
for(j=0;j<G->vexnum;j++)
G->arcs[i][j].adj=INFINITY;
printf("请输入一条边依附的两个顶点和权值:\n");
for(k=0;k<G->arcnum;k++)
{printf("第%d条边:\n",k+1);
printf("起始结点:");
scanf("%s",v1);
printf("结束结点:");
scanf("%s",v2);
printf("边的权值:");
scanf("%d",&w);
i=LocateVex(G,v1);
j=LocateVex(G,v2);
if(i>=0&&j>=0){
G->arcs[i][j].adj=w;
G->arcs[j][i]=G->arcs[i][j];
}}
return G;
}

int FirstAdjVex(MGraph *G,int v)
{
int i;
if(v>=0 &&v<G->vexnum){ //v合理
for(i=0;i<G->vexnum;i++)
if(G->arcs[v][i].adj!=INFINITY) 
return i;
}
return -1;
}

void VisitFunc(MGraph *G,int v)
{
printf("%s ",G->vexs[v].name);

}



int NextAdjVex(MGraph *G,int v,int w)
{
int k;
if(v>=0 && v<G->vexnum && w>=0 && w<G->vexnum)//v,w合理
{ 
for( k=w+1;k<G->vexnum;k++)
if(G->arcs[v][k].adj!=INFINITY) 
return k;
}
return -1;
}

int visited[MAX];


void DFS(MGraph *G,int v)//从第v个顶点出发递归地深度优先遍历图G
{
int w;
visited[v]=1;
VisitFunc(G,v);//访问第v个结点
for(w=FirstAdjVex(G,v);w>=0;w=NextAdjVex(G,v,w))
if(!visited[w]){
DFS(G,w);
//printf("%d ",G->arcs[v][w].adj);
}
}


void DFSTraverse(MGraph *G,char *s)//深度优先遍历
{int v,k;
for(v=0;v<G->vexnum;v++)
visited[v]=0;
k=LocateVex(G,s);

if(k>=0&&k<G->vexnum){
	
for(v=k;v>=0;v--){
if(!visited[v])
DFS(G,v);}

for(v=k+1;v<G->vexnum;v++)
if(!visited[v])
DFS(G,v);
}
}

typedef struct Qnode
{
int vexnum;
struct Qnode *next;
}QNode,*QueuePtr;

typedef struct
{
QueuePtr front;
QueuePtr rear;
}LinkQueue;//设置队列

int InitQueue(LinkQueue *Q)
{
Q->front=Q->rear=(QueuePtr)malloc(sizeof(QNode));
if(!Q->front)exit(0);
Q->front->next=NULL;

return 1;
}//初始化队列 

void EnQueue(LinkQueue *Q,int a )
{ 
QueuePtr p;
p=(QueuePtr)malloc(sizeof(QNode));
if(!p)exit(0);
p->vexnum=a;
p->next=NULL;
Q->rear->next=p;
Q->rear=p;
}


int DeQueue(LinkQueue *Q,int *v)
{ QueuePtr p;

if(Q->front==Q->rear)
{printf("结点不存在!\n");exit(0);}
p=Q->front->next;
*v=p->vexnum;
Q->front->next=p->next;
if(Q->rear==p)
Q->front=Q->rear;
return *v;
}
int QueueEmpty(LinkQueue *Q)
{

if(Q->rear==Q->front)
return 0;
return 1;
}
int Visited[MAX];

void BFSTraverse(MGraph *G,char *str)//广度优先遍历
{int w,u,v,k;

LinkQueue Q;
for(v=0;v<G->vexnum;v++) Visited[v]=0;
InitQueue(&Q);
k=LocateVex(G,str);
for(v=k;v>=0;v--)
if(!Visited[v])
{
Visited[v]=1;
VisitFunc(G,v);
EnQueue(&Q,v);//v入队
while(!QueueEmpty(&Q))
{
DeQueue(&Q,&u);//出队
for(w=FirstAdjVex(G,u);w>=0;w=NextAdjVex(G,u,w))
if(!Visited[w])
{
Visited[w]=1;
VisitFunc(G,v);
EnQueue(&Q,w);
}
}
}

for(v=k+1;v<G->vexnum;v++)
if(!Visited[v])
{
Visited[v]=1;
VisitFunc(G,v);
EnQueue(&Q,v);//v入队
while(!QueueEmpty(&Q))
{
DeQueue(&Q,&u);//出队
for(w=FirstAdjVex(G,u);w>=0;w=NextAdjVex(G,u,w))
if(!Visited[w])
{
Visited[w]=1;
VisitFunc(G,v);
EnQueue(&Q,w);
}
}
}
}


void main()
{
MGraph *G,b;

char v[10];
G=CreatUDN(&b);
printf("请输入起始结点名称:");
scanf("%s",v);
printf("\n深度优先遍历:\n");
DFSTraverse(G,v);
printf("\n广度优先遍历:\n");
BFSTraverse(G,v);
getch();
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -