3.14(链表练习)

题目:编写一个程序,将一个图读入邻接表,

(1)链表:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
using namespace std;
struct Node{
    int data;
    struct Node* next;
};

struct H{
    int id;
    struct Node* First;
    struct H* next;
};
typedef struct H* Tu;

Tu Find(int id,Tu L)
{
    Tu p=L->next;
    while(p->id!=id&&p!=NULL) p=p->next;
    return p;
}

void Insert(int x,Tu L)
{
    Node *h=L->First,*tp,*p;
    p=h;
    while(p->next!=NULL) p=p->next;
    tp=(Node*)malloc(sizeof(struct Node));
    tp->data=x;
    tp->next=NULL;
    p->next=tp;
}

int main(void)
{
    Tu h,p,tp;
    struct Node *p1,*p2;
    int n,m,x,y,i;
    cin>>n>>m;
    h=(Tu)malloc(sizeof(struct H));
    h->next=NULL;
    p=h;
    for(i=1;i<=n;i++)
    {
        tp=(Tu)malloc(sizeof(struct H));
        tp->id=i;
        tp->First=(Node*)malloc(sizeof(struct Node));
        tp->First->next=NULL;
        tp->next=p->next;
        p->next=tp;
        p=p->next;
    }
    
    for(i=0;i<m;i++)
    {
        cin>>x>>y;
        p=Find(x,h);
        Insert(y,p);
        
        p=Find(y,h);
        Insert(x,p);
    }
    
    p=h->next;
    while(p!=NULL)
    {
        p1=p->First->next;
        while(p1!=NULL) 
        {
            printf("(%d,%d) ",p->id,p1->data);
            p1=p1->next;
        }
        printf("\n");
        p=p->next;
    }
    return 0;
}
View Code

(2)游标

#include<iostream>
#include<cstdio>
#include<cstdlib>
using namespace std;
const int maxn = 120;

struct Node1{
    int x1,next1;
};
struct Node1 cur1[maxn];
typedef int List1;
typedef List1 Position1;

void Init1()
{
    int i;
    for(i=0;i<maxn;i++) cur1[i].next1=i+1;
    cur1[i].next1=0;
}

Position1 Malloc1()
{
    Position1 p;
    p=cur1[0].next1;
    cur1[0].next1=cur1[p].next1;
    return p;
}

void Free1(Position1 p)
{
    cur1[p].next1=cur1[0].next1;
    cur1[0].next1=p;
}

Position1 Find1(int x,List1 L)
{
    Position1 p=cur1[L].next1;
    while(cur1[p].x1!=x&&p!=0)
    {
        p=cur1[p].next1;
    }
    return p;
}

Position1 FindEnd(List1 L)
{
    List1 p=L;
    while(cur1[p].next1!=0)
    {
        p=cur1[p].next1;
    }
    return p;
}

void Insert1(int x,List1 L)
{
    Position1 tp=Malloc1(),p;
    p=FindEnd(L);
    cur1[tp].x1=x;
    cur1[tp].next1=cur1[p].next1;
    cur1[p].next1=tp;
}

void Print1(Position1 L1)
{
    Position1 p1=cur1[L1].next1;
    while(p1!=0)
    {
        printf("%d ",cur1[p1].x1);
        p1=cur1[p1].next1;
    }
    printf("\n");
}

struct Node2{
    int x2,next2,first;
};
struct Node2 cur2[maxn];
typedef int List2;
typedef List2 Position2;

void Init2()
{
    int i;
    for(i=0;i<maxn;i++) cur2[i].next2=i+1;
    cur2[i].next2=0;
}

int Malloc2()
{
    Position2 p;
    p=cur2[0].next2;
    cur2[0].next2=cur2[p].next2;
    return p;
}

void Free2(Position2 p)
{
    cur2[p].next2=cur2[0].next2;
    cur2[0].next2=p;
}

Position2 Find2(int x,Position2 L2)
{
    Position2 p=cur2[L2].next2;
    while(cur2[p].x2!=x&&p!=0)
    {
        p=cur2[p].next2;
    }
    return p;
}

void Insert2(int x,List2 L,Position2 p)
{
    Position2 tp=Malloc2();
    cur2[tp].x2=x;
    cur2[tp].first=Malloc1();
    cur1[cur2[tp].first].next1=0;
    cur2[tp].next2=cur2[p].next2;
    cur2[p].next2=tp;
}

void Print2(List2 L2)
{
    Position2 p2=cur2[L2].next2;
    while(p2!=0)
    {
        printf("点%d的邻接点有:\n",cur2[p2].x2); 
        Print1(cur2[p2].first);
        p2=cur2[p2].next2;
    }
    printf("\n");
}

int main(void)
{
    int n,m,i,x,y;
    cin>>n>>m;
    Init1();
    Init2();
    List2 L2,p2;
    L2=Malloc2();
    cur2[L2].next2=0;
    p2=L2;
    for(i=1;i<=n;i++)
    {
        Insert2(i,L2,p2);
        p2=cur2[p2].next2;
    }
    List1 p1,L1;
    while(m--)
    {
        cin>>x>>y;
        p2=Find2(x,L2);
        Insert1(y,cur2[p2].first);
        
        p2=Find2(y,L2);
        Insert1(x,cur2[p2].first);
    }
    
    Print2(L2);
    return 0;
}
View Code

 

posted @ 2018-11-28 11:59  麟阁  阅读(164)  评论(0编辑  收藏  举报