无向图非递归的深度优先非递归遍历


//
//  main.cpp
//  Tu
//All rights reserved.
//
#include <iostream>
#include <stdio.h>//注意
#include <stdlib.h>//注意
#include <string.h>
using namespace std;
#define MAX_VERTEX_NUM  20
#define MAX_VEX  20
typedef string VertexType,VexType;
typedef int ElemType;
typedef int EdgeType,InfoType;
int  Visited[MAX_VEX] ;

typedef struct ArcNode{ //边(弧)结点的类型定义
    int  adjvex;   //边(弧)的另一顶点的在数组中的位置
    ArcNode *nextarc;//指向下一边(弧)结点的指针
    InfoType *info;      //该弧相关信息的指针
}ArcNode;
typedef struct Vnode{//顶点结点及其数组的类型定义
    VertexType data;    //顶点信息
    ArcNode * firstarc;    //指向关联该顶点的边(弧)链表
} Vnode, AdjList[MAX_VERTEX_NUM];
typedef struct {
    AdjList  vertices;
    int  vexnum, arcnum;    //图的当前顶点数和弧数
    int  kind;    //图的种类标志
} ALGraph;    //图邻接表类型
typedef struct
{
    ElemType elem[ MAX_VEX ];
    int top;
}seqstack;
void initStack(seqstack &s)
{
    s.top=0;
}
void push(seqstack &s, int e)
{
    s.elem[s.top]=e;
    s.top++;
}
int pop(seqstack &s, int &e)
{
    s.top--;
    return   e=s.elem[s.top];
}
int stackEmpty(seqstack s)
{
    if(s.top==0)
        return 1;
    else return 0;
}

int  LocateVex(ALGraph  &G , VexType vp)
{
    int  k=0 ;
    for (k=0 ; k<G.vexnum ; k++)
    {if (G. vertices[k].data==vp)
        return(k) ;}
    return(-1) ;     /*  图中无此顶点  */
}
void CreatALGraph(ALGraph &G)//无向图的创建
{
    string v1,v2;
    int i,j,k;
    ArcNode *p1,*p2,*p,*q;
    cin>>G.vexnum>>G.arcnum;//输入顶点数和边数
    for(i=0;i<G.vexnum;i++)
    {
        cin>>G.vertices[i].data;//输入顶点信息
        G.vertices[i].firstarc=NULL;
    }
    for(k=0;k<G.arcnum;k++)
    {
        cin>>v1>>v2;
        i=LocateVex(G,v1);
        j=LocateVex(G,v2);
        p1=new ArcNode;
        p1->adjvex=j;
        p1->nextarc=NULL;
        p=G.vertices[i].firstarc;
        if(p==NULL)
            G.vertices[i].firstarc=p1;
        else
        {
            while(p->nextarc)
            {
                p=p->nextarc;
            }
            p->nextarc=p1;
        }
        p2=new ArcNode;
        p2->adjvex=i;
        p2->nextarc=NULL;
        q=G.vertices[j].firstarc;
        if(q==NULL)
            G.vertices[j].firstarc=p2;
        else
        {
            while(q->nextarc)
            {
                q=q->nextarc;
            }
            q->nextarc=p2;
        }
    }
}


void OutputALGraph(ALGraph &G)//邻接表的输出
{   int i;
    for(i=0;i<G.vexnum;i++)
    {   ArcNode *s;
        cout<<i<<" "<<G.vertices[i].data; //顶点信息
        s=G.vertices[i].firstarc;
        while(s!=NULL)
        {  printf(" %d",s->adjvex);
            s=s->nextarc;   }
        printf("\n");
    }
}

int FirstAdjvex(ALGraph G,int u)
{
    ArcNode *t;
    t=G.vertices[u].firstarc;
    if(t!=NULL)
        return t->adjvex;
    else
        return -1;
}
int NextAdjvex(ALGraph G,int u,int w)
{
    ArcNode *t;
    t=G.vertices[u].firstarc;
    while(t!=NULL)
    {
        if(t->adjvex!=w)
            t=t->nextarc;
        else if(t->nextarc!=NULL)
            return t->nextarc->adjvex;
        else
            return -1;
    }
    return -1;
}
void BFS(ALGraph G,int v)
{   seqstack q;
    int u,w;
    cout<<G.vertices[v].data<<" ";
    Visited[v]=true;
    initStack(q);
    push(q,v);
    while(!stackEmpty(q))
    {
        pop(q,u);
        for(w=FirstAdjvex(G,u);w>=0;w=NextAdjvex(G,u,w))
            if(!Visited[w])
            {
                cout<<G.vertices[w].data<<" ";
                Visited[w]=true;
                push(q,w);
            }
    }
}

void DFS(ALGraph G,int v)
{
    seqstack s;
    int k,w;
    initStack(s);
    push(s,v);
    while(!stackEmpty(s))
    {
        pop(s,k);
        if(!Visited[k])
        {
            Visited[k]=true; cout<<G.vertices[k].data<<" ";
            for(w=FirstAdjvex(G,k);w>=0;w=NextAdjvex(G,k,w))
            {
                if(!Visited[w])
                {
                    push(s,w);
                }
            }
        }
    }
}
int main()
{
    ALGraph G;
    CreatALGraph(G);
    //OutputALGraph(G);
    DFS(G,0);
    return 0;
}




评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Laura_Wangzx

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值