图的邻接表

//DATE:2006-12-03    BY:snowhill
/* 1---2   以邻接表存放应为: 1->5->3->2
     | \  / |       2->4->3->1
     |  3  |       3->5->4->2->1
     | /  \ |        4->5->3->2
    5---4       5->4->3->1
 */

/*  图的邻接表  以a[1]为起始地起址存放 */
#include "iostream.h"
const int n=5;
const int e=8;
int visited[n+1]; //访问标志数组
struct link
{
 int data;
 link *next;
};
struct node
{
 int v;     //顶点信息
 link *next;
}a[n+1];

/* 无向图的建立 */
void createlink()
{
 int i,j,k;
 link *s;
 //初始化
 for(i=1;i<=n;i++)
 {
  a[i].v=i;
  a[i].next=NULL;
 }

 /*以头插法建立 */

  for(k=1;k<=e;k++)
 {
  cout<<"请输入一条边:";
  cin>>i>>j;
  cout<<endl;
  s=new link;
  s->data=j;
  s->next=a[i].next;
  a[i].next=s;
  s=new link;
  s->data=i;
  s->next=a[j].next;
  a[j].next=s;
 }
}

/* 深度优先搜索 */
void dfs(int i)
{
  link *p;
  cout<<a[i].v<<" ";
  visited[i]=1;
  p=a[i].next;
  while(p!=NULL)
  {
   if(!visited[p->data])
   dfs(p->data);
   p=p->next;
  }
}


void main()

    link *p;char yn='y';int k;
 createlink();
 while(yn=='y')
 {  
  cout<<"你建立的图为:"<<endl;
  for(int i=1;i<=n;i++)
  {
  p=a[i].next;
  cout<<a[i].v<<"->";
  while(p->next!=NULL)
   {
    cout<<p->data<<"->";
    p=p->next;
   }
  cout<<p->data<<endl;
  }
    for(i=1;i<=n;i++)
 visited[i]=0;
 cout<<"请输入深度优先搜索的顶点:";
 cin>>k;
 cout<<endl;
  
 dfs(k);
 cout<<"要继续遍历吗(Y/N)?";
 cin>>yn;
 }
 
   
}

posted on 2006-12-03 16:42 snowhill 阅读(2325) 评论(3)  编辑 收藏 引用 所属分类: data structure

评论

# re: 图的邻接表 2009-01-20 23:52 vvilp

受教了  回复  更多评论   

# re: 图的邻接表 2010-08-04 11:35 学习

只出现new而没有delete
会不会内存泄露?  回复  更多评论   

# re: 图的邻接表 2011-03-29 13:52 snowhill

会哦...当时没考虑.  回复  更多评论   


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


<2011年3月>
272812345
6789101112
13141516171819
20212223242526
272829303112
3456789

导航

公告

又一年...........

留言簿(3)

随笔分类(13)

文章分类(131)

文章档案(124)

c++

java

linux

oracle

常用软件

其他

网络配置

系统安全

音乐

搜索

最新评论

阅读排行榜