这是我写的程序:
#include <stdio.h>
#include <stdlib.h>
typedef int elemtype;
typedef struct node
{
struct node *prior;
struct node *next;
elemtype data;
} dlink;
dlink * initlist(int n)
{
dlink *a,*temp,*next;
a=(dlink *)malloc(sizeof(dlink));
a->prior=0;
temp=a;
int i;
for (i=1;i<=n;i++)
{
next=(dlink *)malloc(sizeof(dlink));
scanf("%d",&next->data);
next->prior=temp;
temp->next=next;
temp=next;
}
next->next=0;
return a;
}
void list(dlink *a)
{
int i;
dlink *temp;
temp=a;
for (i=0;temp->next !=0;i++)
{
temp=temp->next;
printf ("%d ",temp->data);
}
printf("\n");
for (i=0;temp->prior != 0;i++);
{
printf("%d",temp->data);
temp=temp->prior;
}
printf("\n");
}
void main()
{
dlink *a;
a=initlist(5);
list(a);
}
运行之后,到了输出是只能顺序输出,到了该反向输的时候就不行了,请各位帮忙看看为什么.谢了!
----------------解决方案--------------------------------------------------------
for (i=0;temp->prior != 0;i++);//分号去掉。
另外最好再编个函数释放申请的内存单元。
----------------解决方案--------------------------------------------------------