#include<iostream>

using namespace std;

#define MVNum 100

#define MaxInt 32767//代表无穷大

#define MVNum 100//最大顶点数 

int visited[100]={0}; 

/*邻接矩阵表示图*/ 

typedef char VerTexType;//假设顶点的数据类型为字符型

typedef int ArcType;//假设边的权值类型为整型

typedef struct 

{

VerTexType vexs[MVNum];//顶点表

AreType arcs[MVNum][MVNum];//邻接矩阵

int vexnum,arcnum;//图的点数和边数 

 }AMGraph;

 /*创建邻接矩阵*/ 

Status CreateUDN(AMGraph &G)

{

cin>>G.vexnum>>G.arcnum;//输入总顶点数边总边数

for(int i=0;i<G.vexnum;i++)

{

cin>>G.vexs[i];//输入点的信息 

}

for(int i=0;i<G.vexnum;i++)//初始化邻接矩阵 

for(int j=0;j<G.vexnum;j++)

G.arcs[i][j]=MaxInt;

for(int k=0;k<G.arcnum;k++)

{  int w;//w为权值 

cin>>v1>>v2>>w;

i=LocateVex(G,v1); 

j=LocateVex(G,v2);

G.arcs[i][j]=w;

G.arcs[j][i]=G.arcs[i][j]; 

}

return OK; 

 } 

/*邻接表表示图 */

typedef struct ArcNode  //边结点 

{ int adjvex;

  struct ArcNode *nextarc;

}ArcNode;

 

typedef struct VNode  //顶点(表头)信息 

{ int data;

  ArcNode *firstarc;//向后接边节点 

}VNode,AdjList[MVNum];


typedef struct  //邻接表 

{ AdjList vertices;

  int vexnum,arcnum;

}ALGraph;


int LocateVex(ALGraph G,int v)

{ for(int i=0;i<G.vexnum;i++)

{

if(G.vertices[i].data==v)

return i;//返回该节点的下标 

}

}

/*创建邻接表表示图 */

int CreateUDG(ALGraph &G)

{ printf("请分别输入总顶点数和总边数:");

  cin>>G.vexnum>>G.arcnum;

  int i,j,k;

  for(i=0;i<G.vexnum;i++)

  { cout<<"请输入顶点值"<<endl; 

    cin>>G.vertices[i].data;

    G.vertices[i].firstarc=NULL;

  }

  for(k=0;k<G.arcnum;k++)

  { int v1,v2;

    cout<<"请输入该边依附的顶点:"<<endl;

    cin>>v1>>v2; 

    i=LocateVex(G,v1);

    j=LocateVex(G,v2);

    ArcNode *p1=new ArcNode;

    p1->adjvex=G.vertices[j].data;//将节点值赋值 

    p1->nextarc=G.vertices[i].firstarc;

    G.vertices[i].firstarc=p1;

    

    ArcNode *p2=new ArcNode;

    p2->adjvex=G.vertices[i].data;

    p2->nextarc=G.vertices[j].firstarc;

    G.vertices[j].firstarc=p2;

  }

  return 1;


/*DFS深度遍历图*/ 

void DFS_AL(ALGraph G,int v)//下标v 

{

cout<<G.vertices[v].data<<" ";//输出遍历的节点值 

visited[v]=1;

ArcNode *p=G.vertices[v].firstarc;

while(p)

{

int w=p->adjvex;//w为节点值 

if(visited[LocateVex(G,w)]==0)

DFS_AL(G,LocateVex(G,w));

p=p->nextarc;

}

}

/*普里姆算法*/

struct 

{

VerTexType adjvex;//最小边在U中的那个顶点

ArcType lowcost;//最小边的权值 

 }closedge[MVNum];

 void MiniApanTree_Prim(AMGraph G,VerTexType u)//u为起点 

 {

  int k=LocateVex(G,u);

  for(int j=0;j<G.vexnum;j++)

  {

  if(j!=k)

  closedge[j]={u,G.arcs[k][j]};//adjvex,lowcost 

}

closedge[k].lowcost=0;

for(int i=1;i<G.vexnum;i++)//只需要选n-1个点 

{

k=Min(closedge); 

  } 

 

  } 


int main()

{ ALGraph G;

  CreateUDG(G);

  int i;

  for(i=0;i<G.vexnum;i++)

  { VNode temp=G.vertices[i];

    ArcNode *p=temp.firstarc;//指向下一个邻接点  

    if(p==NULL)

    { cout<<G.vertices[i].data<<endl;

    }

    else

    { cout<<temp.data;

      while(p)

      { 

  cout<<"->"<<p->adjvex;

        p=p->nextarc;

  } 

}

cout<<endl;

  }

  int v;

  cout<<"请输入出发顶点值:"; 

  cin>>v;  

  DFS_AL(G,LocateVex(G,v));//输入顶点值,但是以下标运算 

   return 0; 

}

/*图的邻接表过程下标和节点值的操作是关键*/ 

/*在一个连通网的所有生成树中,各边的代价之和最小的那颗生成树称为该连通树的最小代价生成树*/ 


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论