69,371
社区成员
发帖
与我相关
我的任务
分享
#include <stdio.h>
#include <stdlib.h>
#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0
typedef int Status;
typedef int ElemType;
static Status visit(ElemType c)
{
printf("%d ",c);
return OK;
}
typedef struct Node
{
ElemType data;
struct Node *next;
}Node,*LinkList;
/* 初始化顺序线性表 */
static Status InitList(LinkList *L)
{
*L=(LinkList) malloc(sizeof(Node));
if(!(*L))
return ERROR;
(*L)->next=NULL;
return OK;
}
/* 初始条件:顺序线性表L已存在。操作结果:返回L中数据元素个数 */
static int ListLength(LinkList L)
{
int i=0;
LinkList p;
p=L->next;
while(p)
{
i++;
p=p->next;
}
return i;
}
/* 初始条件:顺序线性表L已存在,1≤i≤ListLength(L), */
/* 操作结果:在L中第i个位置之前插入新的数据元素e,L的长度加1 */
static Status ListInsert(LinkList *L,int i,ElemType e) /*???这里的LinkList *L,我能不能改成LinkList L???*/
{
int j;
LinkList p,s;
p=*L; /*???这里改成p=L???*/
j=1;
while(p && j<i) /* 寻找第i个结点,且让p指向i之前的那一个节点 */
{
p=p->next;
j++;
}
if(!p || j>i)
return ERROR;
s=(LinkList)malloc(sizeof(Node));
s->data=e;
s->next=p->next;
p->next=s;
return OK;
}
/* 初始条件:顺序线性表L已存在 */
/* 操作结果:依次对L的每个数据元素输出 */
static Status ListTraverse(LinkList L)
{
LinkList p=L->next;
while(p)
{
visit(p->data);
p=p->next;
}
printf("\n");
return OK;
}
main()
{
Status i;
ElemType e;
LinkList L;
int j,k;
i=InitList(&L);
printf("初始化L后:ListLength(L)=%d\n",ListLength(L));
for(j=1;j<=5;j++)
{
i=ListInsert(&L,1,j);
}
printf("在L的表头依次插入1~5后:L.data=");
ListTraverse(L);
return 0;
}
static Status ListInsert(LinkList L,int i,ElemType e)
p=L; /*???这里改成p=L???*/
调用的时候:
ListInsert(L,1,j);
另外main函数前要加上返回值类型。