⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 7_3.txt

📁 C语言数据结构知识原代码 C语言数据结构知识原代码C语言数据结构知识原代码
💻 TXT
字号:
#include<stdio.h>
typedef struct node{
  int data;
  struct node *next;
 }Node;
typedef struct adjnode{
  char ch[10];
  Node *firstarc;
 }Adjnode;
locate(Adjnode *adj,int n,char *s)
 {
  int i;
  for(i=0;i<n;i++)
   if(strcmp(adj[i].ch,s)==0)return i;
  return -1;
 }
createadj(Adjnode **adj,int n,int e)
 {char *s,*t; int i,j,k;
  Node *p,*q;
  printf("输入各顶点的字符串.\n");
  for(i=0;i<n;i++)
   { gets(s);
    strcpy((*adj)[i].ch,s);
    (*adj)[i].firstarc=NULL;
   }
    printf("请输入各条边.\n");  /*如v1回车v2回车表明有v1到v2的边*/
   for(i=1;i<=e;i++)
   {
    gets(s);
    gets(t);
    j=locate(*adj,n,s);
    k=locate(*adj,n,t);   
    if(k>=0 && j>=0){
     p=(Node *)malloc(sizeof(Node));
     p->data=k;p->next=NULL;
     q=(Node *)malloc(sizeof(Node));
     q->data=j;q->next=NULL;
     p->next=(*adj)[j].firstarc;
     (*adj)[j].firstarc=p;
     q->next=(*adj)[k].firstarc;
     (*adj)[k].firstarc=q;
     }
     else
     printf("边的顶点输入不正确!\n");
   }
 }
 createinvadj(Adjnode *adj,Adjnode **invadj,int n,int e)
 {
  Node *p,*q;int i,j;
  for(i=0;i<n;i++)                    /*逆邻接表初始化*/
   {
    strcpy((*invadj)[i].ch,adj[i].ch);
    (*invadj)[i].firstarc=NULL;
    }
    for(i=0;i<n;i++)                  /*建立逆邻接表*/
   {
    p=adj[i].firstarc;
    while(p){
     q=(Node *)malloc(sizeof(Node));
     j=p->data;
     q->data=i;
     q->next=(*invadj)[j].firstarc;
     (*invadj)[j].firstarc=q;
     p=p->next;
    }
   }
 }
printadj(Adjnode *adj,int n)
 {
  Node *p;int i;
   for(i=0;i<n;i++)                  
    {
    p=adj[i].firstarc;
    while(p){
     printf("%s->%s\n",adj[i].ch,adj[p->data].ch);
     p=p->next;
     }
     } 
  }

main()
{
 int n,e,i;
 Adjnode *adj,*invadj;
 printf("输入无向图的顶点数和边数.\n");
 do
 scanf("%d%d",&n,&e);
 while(n<=0 || e<=0);
 getchar();
 adj=(Adjnode *)malloc(sizeof(Adjnode)*n);
 invadj=(Adjnode *)malloc(sizeof(Adjnode)*n);
 createadj(&adj,n,e);
 createinvadj(adj,&invadj,n,e);
printadj(adj,n);
 /*for(i=0;i<n;i++)
  printf("%s\n",adj[i].ch);*/

printadj(invadj,n);
 }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -