静态链表:静态链表的结构:
(1)整体是一个数组,包括data域和next域;其中next保存的是下一个格子的下标,并且最后一格保存空闲链的表头;
(2)静态链表有两条链,0号下标是有效链的表头;1号下标是空闲链的表头;
(3)在判断链表是否为满的时候只要看空闲链的表头next域的数据是否是1,如果是1就证明已满;
在判断链表是否为空只要看有效链表头next域存储的数据是否是0,如果是0,则为空;
(4)我们在给链表插入数据时,分为两步:
第一步:在空闲链上找空闲节点,将放入空节点中;
第二步:将此填充数据的节点踢出空闲链,并将剩余的空闲链连接起来;再将此节点连接到有效链上即可;
(5)在进行删除操作时,必须先找到要删除的节点的前驱,然后再将它踢出有效链,连接到空闲链上;
代码如下:
#define SIZE 10
typedef struct SNode
{
int data;//数据
int next; //指针,下一个节点的下标
}SNode,*PSList,SList[SIZE];//SList是SNod
/*
//初始化静态链表
void InitSList(PSList ps)
{
if(ps == NULL)
return ;
for(int i=0;i<SIZE;i++)
{
ps[i].next=i+1;//每一个next域保存的是下一个格子的下标
}
ps[0].next=0;//最后有效链的next域存放的是0
ps[SIZE-1].next=1;//最后一个格子的next域存放的是1;
}
//判满
static bool IsFull(PSList ps)
{
return ps[1].next == 1;
}
//判空
bool IsEmpty(PSList ps)
{
return ps[0].next==0;
}
//头插
bool Insert_head(PSList ps,int val)
{
if(IsFull(ps))
{
return false;
}
int k=ps[1].next;//找到一个空闲节点;
ps[1].next=ps[k].next;// 将此节点踢出空闲链
ps[k].data=val;//将数据放入此节点中;
ps[k].next=ps[0].next;//将此节点连接到有效链中;
ps[0].next=k;// 头插
return true;
}
//查找前驱
static int SearhcPri(PSList ps,int key)
{
assert(ps!=NULL);
for(int p=0;ps[p].next!=0;p=ps[p].next)
{
if(ps[ps[p].next].data==key)//p下标next域所存放的下标对应的data==key 则p为要删除的元素的前驱
{
return p;
}
}
return false;
}
//删除某个节点
//先找到要删的节点的前驱 在将前驱的next域指向要删节点的next域
//再将要删的节点挂到空闲链上
bool Delete(PSList ps,int key)
{
assert(ps!=NULL);
int p=SearhcPri(ps,key);
if(p==NULL)
{
return false;
}
int q=ps[p].next;//找到要删的节点的下标;
ps[p].next=ps[q].next;//将此节点踢出有效链;
ps[q].next=ps[1].next;//将此节点连接到空闲链上;
ps[1].next=q;//空闲链的表头链接此节点的下标,头插;
return true;
}
//找到其前驱 就可以找到key的下标
int Search(PSList ps,int key)
{
int k=SearhcPri(ps,key);
if(k==NULL)
{
return false;
}
return ps[k].next;//前驱的next保存着key的下标
}
//打印节点数据 从有效链开始遍历
void Show(PSList ps)
{
int p;
for(p=ps[0].next;p!=0;p=ps[p].next)
{
printf("%d ",ps[p].data);
}
printf("\n");
}
void Clear(PSList ps)
{
ps[0].next=0;
}
int main()
{
SList s;
InitSList(s);
for(int i=0;i<10;i++)
{
Insert_head(s,i);
}
printf("slist delete before::\n");
Show(s);
Delete(s,5);
printf("slist delete after::\n");
Show(s);
//int q=SearhcPri(s,2);
//printf("%d\n",q);
//Delete(s,2);
//Show(s);
return 0;
}*/
具体操做如下图图例所示: