无向图作业

设无向图如下:C=(D,R),其中:
D={14,22,36,48,57,69,9,74,83},
R={(14,22),(14,83),(14,36),(14,48),(22,36),(22,57),(22,69),(36,83),(48,57),(48,74),(48,83),(57,9),(57,74),(69,9),(9,74)}
要求:
(1)绘制此图。
(2)给出此图的邻接矩阵和邻接表表示。
(3)设计算法实现图的邻接矩阵和邻接表并进行输出。
(4)在(3)的基础上,给出图的深度优先遍历的非递归算法和图的广度 优先算法。并将遍历结果存储到一维数组t1和t2中。
(5)利用t1数组实现二分查找算法,并进行算法分析。
(6)利用t2数组实现shell排序算法。
解答:
(1)在这里插入图片描述
(2)在这里插入图片描述
在这里插入图片描述
(3)

#include <iostream>
#include <stack>
using namespace std;
#define MaxSize 50
typedef int ElemType;
bool visited1[MaxSize];
bool visited2[MaxSize];
unsigned int num=1,num1=1;
typedef struct
{ 
	int arc[MaxSize][MaxSize];
	int vextexnum,arcnum;
	ElemType vertex[MaxSize];
}MGraph;
typedef struct ArcNode
{
	int adjvex;
	struct ArcNode *next;
}ArcNode;
typedef struct VertexNode
{
	ElemType vertex;
	ArcNode *firstedge;
}VertexNode;
typedef struct ALGraph
{ 
	VertexNode adjlist[MaxSize];
	int vextexnum,arcnum;
}ALGraph;
int xuhao(ElemType a[],ElemType n)//序号查询函数,查找出该元素位于数组中的第几项,n为元素项
{
	int i;
	for(i=0;a[i]!=NULL;i++)
	{
		if(n==a[i])
		break;
	}
	return i;
}
void MGraph1(MGraph &g,ElemType a[],int n,int e)//邻接矩阵函数,g为需要生成的邻接矩阵数组,a为顶点数组,n为顶点个数,e为边的条数
{
	g.vextexnum=n;
	g.arcnum=e;
	int i,j,k;
	ElemType x,y;
	for(i=0;i<g.vextexnum;i++)
		g.vertex[i]=a[i];
	for(i=0;i<g.vextexnum;i++)
		for(j=0;j<g.vextexnum;j++)
			g.arc[i][j]=0;
	for(k=0;k<g.arcnum;k++)
	{
		cin>>x>>y;
		i=xuhao(a,x);
		j=xuhao(a,y);
		g.arc[i][j]=1;
		g.arc[j][i]=1;
	}
}
void ALGraph1(ALGraph &g,ElemType a[],int n,int e)//邻接表函数,g为需要生成的邻接表,a为顶点数组,n为顶点个数,e为边的条数
{
	g.vextexnum=n;
	g.arcnum=e;
	int i,j,k;
	ElemType x,y;
	ArcNode *s,*m;
	for(i=0;i<g.vextexnum;i++)
	{
		g.adjlist[i].vertex=a[i];
		g.adjlist[i].firstedge=NULL;
	}
	for(k=0;k<g.arcnum;k++)
	{
		cin>>x>>y;
		i=xuhao(a,x);
		j=xuhao(a,y);
		s=new ArcNode;
		m=new ArcNode;
		s->adjvex=j;
		s->next=g.adjlist[i].firstedge;
		g.adjlist[i].firstedge=s;
		m->adjvex=i;
		m->next=g.adjlist[j].firstedge;
		g.adjlist[j].firstedge=m;
	}
}
void DispMat(MGraph &g)//邻接矩阵的输出函数,g为需要输出的邻接矩阵
{
	int i,j;
	for(i=0;i<g.vextexnum;i++)
		cout<<g.vertex[i]<<"  ";
	cout<<endl;
	for(i=0;i<g.vextexnum;i++)
	{
		for(j=0;j<g.vextexnum;j++)
			if(g.arc[i][j]==0)
				cout<<"0"<<"   ";
			else
				cout<<g.arc[i][j]<<"   ";
			cout<<endl;
	}
}
void DispAdj(ALGraph &G)//邻接表的输出函数,g为需要输出的邻接表
{
	int i;
	ArcNode *p;
	for(i=0;i<G.vextexnum;i++)
	{
		p=G.adjlist[i].firstedge;
		  if(p!=NULL)
			  cout<<i<<"  ";
		  while(p!=NULL)
		  {
			  cout<<p->adjvex<<"  ";
			  p=p->next;
		  }
		  cout<<endl;
	}
}
void DFS(MGraph g,int v,ElemType t1[])
{
    stack<int> s;
    s.push(v); 
    cout<<g.vertex[v]<<" "; 
    int t=v;
    visited1[v]=1;
    for(int j=v;j<=g.vextexnum;j++){
        if(g.arc[v][j]==1&&visited1[j]==0)
		{
            visited1[j]=1;
            s.push(j);
            cout<<g.vertex[j]<<" ";
			t1[num]=g.vertex[j];
			num++;
            v=j;j=0;
        }
        if(j==g.vextexnum)
		{
            if(t==s.top())
            break;
            s.pop();
            v=s.top();j=0;
        }
    }
}
void BFSraverse(MGraph g,int v,ElemType t2[])//广度优先遍历函数,g为需要遍历的图,v为开始遍历的序号,t2为需要存储遍历结果的数组
{
	int j;
	int front,rear;
    int Q[MaxSize];
    front=rear=-1;
	cout<<g.vertex[v]<<" ";
	t2[num1]=g.vertex[v];
	visited2[v]=1;
	Q[++rear]=v;
	while(front!=rear)
	{
		v=Q[++front];
		for(j=0;j<g.vextexnum;j++)
		{ 
			if(g.arc[v][j]==1&&visited2[j]==0)
			{ 
				num1++;
				t2[num1]=g.vertex[j];
				cout<<g.vertex[j]<<" ";
				visited2[j]=1;
				Q[++rear]=j;
			}
		}
	}
}
void mp(ElemType a[])//冒泡排序函数,a数组为需要排序的数组
{
	int i,j,k;
	for(i=0;i<8;i++)
		for(j=1;j<9;j++)
		{
			if(a[j]>a[j+1])
			{
				k=a[j+1];
				a[j+1]=a[j];
				a[j]=k;
			}
		}
}
int erfen(ElemType r[],int low,int high,int k)//二分法查找函数,r数组为需要查找的数组,low为该数组的最小的元素序号,high为最高的序号,k为需要查找的元素
{
   int mid;
   if(low<=high )
{
   mid=(low+high)/2;
   if(k==r[mid])
   return mid;   
   else if(k<r[mid])
       return erfen(r,low,mid-1,k);
   else 
	   return erfen(r,mid+1,high,k);
}
   else return 0;
}
void shell(ElemType r[],int n,int d)//shell排序函数,r数组为需要排序的数组,n为该数组最大的元素序号,d为shell排序中的间隔数
{
	int i,j;
	for(i=d+1;i<=n;i++) 
	{
	    r[0]=r[i];                  
	    j=i-d;                   
	   while(j>0&&r[0]<r[j])
	   { 
	        r[j+d]=r[j];     
	       j=j-d;                 
	    }
	   r[j+d]=r[0];
	 }
}
void main()
{ 
	int i,n,x,d;
	ElemType t1[20],t2[20];
	MGraph g;
	ALGraph g1;
	ElemType a[]={14,22,36,48,57,69,9,74,83};
	cout<<"请输入图的15条边两端的顶点:"<<endl;
	MGraph1(g,a,9,15);
	cout<<"此图的邻接矩阵为:"<<endl;
	DispMat(g);
	cout<<endl;
	cout<<"请再次输入图的15条边两端的顶点:"<<endl;
	ALGraph1(g1,a,9,15);
	cout<<"此图的邻接表为:"<<endl;
	DispAdj(g1);
	cout<<"深度优先为:";
	DFS(g,0,t1);
	cout<<endl;
	cout<<"广度优先为:";
	BFSraverse(g,0,t2);
	cout<<endl;
	mp(t1);
	cout<<"请输入您需要查找的数值:";
	cin>>x;
	n=erfen(t1,1,9,x);
	if(n==0)
		cout<<"没有此数值"<<endl;
	else
		cout<<"二分查找的结果为:"<<"位于冒泡排序后的数组的第"<<n-1<<"个"<<endl;
	cout<<"shell排序的结果为:";
	for(d=4;d>=1;d=d/2)
	shell(t2,9,d);
	for(i=1;i<10;i++)
	cout<<t2[i]<<" ";
	cout<<endl;
}```

需要输入的数据:
14 22
14 83
14 36
14 48
22 36
22 57
22 69
36 83
48 57
48 74
48 83
57 9
57 74
69 9
9 74
在这里插入图片描述
在这里插入图片描述
(4)在这里插入图片描述
(5)在这里插入图片描述
(6)

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值