十字链表表示法,构造有向网(C++图)

#include<string>
#include <iostream>
using namespace std;
#define INFINITY INT_MAX
#define MAX_VERTEX_NUM 20//最大顶点个数 
typedef enum{DG,DN,UDG,UDN}GraphKind;
typedef struct ArcBox{
	int tailvex,headvex;
	int info;
	struct ArcBox *hlink,*tlink;
}ArcBox;
typedef struct VexNode{
	string name;
	ArcBox *firstin,*firstout;
}VexNode;
typedef struct{
	VexNode xlist[MAX_VERTEX_NUM];
	int vexnum,arcnum;//图的当前顶点数和弧数 
	GraphKind kind;//图的种类标志 
}OLGraph;
int LocateVex(OLGraph G,string v)
{
	int i;
	for(i=0;i<G.vexnum;i++)
	{
		if(G.xlist[i].name==v)break;
	}
	return i;
}
void CreateDN(OLGraph &G)
{ 
    int i,j,k;
    string v1,v2;
    ArcBox *s;
	cout<<"图的顶点数:";
	cin>>G.vexnum;
	cout<<"图的弧数:";
	cin>>G.arcnum;
	cout<<"图的所有顶点名:";
	for(i=0;i<G.vexnum;i++)
	{
		cin>>G.xlist[i].name;//构造顶点向量
		G.xlist[i].firstin=NULL;G.xlist[i].firstout=NULL;//初始化指针 
	} 
	cout<<"输入各弧:";
	for(k=0;k<G.arcnum;k++)//输入各弧并构造十字链表 
	{
		cin>>v1>>v2;//输入各弧起点和终点 
		i=LocateVex(G,v1);
		j=LocateVex(G,v2);//确定v1、v2在G中位置 
		s=new ArcBox;
		s->tailvex=i;s->headvex=j;
		s->tlink=G.xlist[i].firstout;s->hlink=G.xlist[j].firstin;
		cin>>s->info;//对弧结点赋值 
		G.xlist[i].firstout=G.xlist[j].firstin=s;//完成在入弧和出弧链头的插入 
	}
}
int main()
{
	OLGraph G;
	G.kind=DN;
	CreateDN(G);
	return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值