实现的无向图广度优先遍历

实现的无向图广度优先遍历

ID:12837741

大小:38.50 KB

页数:5页

时间:2018-07-19

实现的无向图广度优先遍历_第1页
实现的无向图广度优先遍历_第2页
实现的无向图广度优先遍历_第3页
实现的无向图广度优先遍历_第4页
实现的无向图广度优先遍历_第5页
资源描述:

《实现的无向图广度优先遍历》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、用C++实现的实现无向图的广度优先遍历#include#includeusingnamespacestd;//图的邻接表存储表示#defineMAX_NAME5//顶点字符串的最大长度#defineMAX_VERTEX_NUM20typedefcharVertexType[MAX_NAME];typedefstructArcNode{//表结点intadjvex;structArcNode*nextarc;int*info;}ArcNode;typedefstructVNode{//头结点VertexTypedata;ArcNod

2、e*firstarc;}VNode,AdjList[MAX_VERTEX_NUM];typedefstruct{//图AdjListvertices;intvexnum,arcnum;stringkind;}ALGraph;//队列的链式存储结构P61(元素类型为整形)typedefstructQNode{intdata;structQNode*next;}QNode,*QueuePtr;typedefstruct{QueuePtrfront;//队头指针QueuePtrrear;//队尾指针}LinkQueue;intInitQueue(LinkQueue&Q)/

3、/构造一个空队列{Q.front=Q.rear=(QueuePtr)malloc(sizeof(QNode));if(!Q.front)exit(-1);//存储分配失败Q.front->next=NULL;return1;}boolQueueEmpty(LinkQueueQ)//判空{if(Q.front==Q.rear)returntrue;returnfalse;}intEnQueue(LinkQueue&Q,inte)//队列的插入(尾){QueuePtrp;p=(QueuePtr)malloc(sizeof(QNode));if(!p)exit(-1);/

4、/存储分配失败p->data=e;p->next=NULL;Q.rear->next=p;Q.rear=p;//尾指针后移return1;}intDeQueue(LinkQueue&Q,int&e)//队列的删除(首){QueuePtrp;if(Q.front==Q.rear)return0;//队列空,返回0p=Q.front->next;e=p->data;Q.front->next=p->next;if(Q.rear==p)Q.rear=Q.front;//尾指针回送free(p);return1;}intLocateVex(ALGraphG,VertexTy

5、peu)//返回顶点在图中的位置,无则返回-1{for(inti=0;i>G.kind;cout<<"请输入图的顶点数,边数:";cin>>G.vexnum>>G.arcnum;cout<<"

6、请输入各个顶点的值";for(inti=0;i>G.vertices[i].data;G.vertices[i].firstarc=NULL;}if(G.kind=="DN"

7、

8、G.kind=="UDN")//网cout<<"请顺序输入每条弧(边)的弧尾、弧头及权值:";elsecout<<"请顺序输入每条弧(边)的弧尾和弧头:";for(intk=0;k

9、

10、G.kind=="UDN")cin>>va>>vb>>w;else

11、cin>>va>>vb;inti=LocateVex(G,va);//弧尾intj=LocateVex(G,vb);//弧头p=(ArcNode*)malloc(sizeof(ArcNode));p->adjvex=j;if(G.kind=="DN"

12、

13、G.kind=="UDN"){p->info=(int*)malloc(sizeof(int));*(p->info)=w;}elsep->info=NULL;p->nextarc=G.vertices[i].firstarc;//插在表头G.vertices[i].firstarc=p;if(G.kind=="

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。