双向循环链表
#include<iostream>
using namespace std;
typedef int ElemType;
typedef struct Node
{
ElemType data;
Node *next,*prior;
}LinkNode,*LinkList;
void creat_List(LinkList&L,int length)
{
LinkNode *p,*first=L;
while(length-->0)
{
p=new LinkNode;
cin>>p->data;
L->next=p;
p->prior=L;
L=p;
}
L->next=first;
first->prior=L;
}
void print(LinkList&real)
{
LinkList last=real;
LinkList head=real->next->next;
while(head!=real->next)
{
cout<<head->data<<'\t';
head=head->next;
}
cout<<endl;
while(last->prior!=real)
{
cout<<last->data<<'\t';
last=last->prior;
}
cout<<endl;
}
void main()
{
LinkNode *first=new LinkNode;
cout<<"请输入数据的个数"<<endl;
int number;
cin>>number;
if(number<1)
{
cout<<"输入数据有误:"<<endl;
exit(0);
}
creat_List(first,number);
print(first);
}