数据结构之静态链表

静态链表:静态链表的结构:
(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;
}*/

具体操做如下图图例所示:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值