10.6静态链表

//10.6 静态链表
#include <stdio.h>
#include <stdlib.h>

#define MAXSIZE 30
typedef struct
{
	char data;                  //data 为节点的数信息
	int cursor;                 //cursor 标识直接后继节点
}SNode;                         //静态链表节点类型

void InsertList(SNode L[], int i, char x)  //在静态链表中插入元素
{
	int j, j1, j2, k;
	j = L[0].cursor;                       //j 指向第一个数据节点
	if (1 == i)
	{
		if (0 == j)                        //静态链表为空
		{
			L[1].data = x;                 //将小放入节点L[1]中
			L[0].cursor = 1;               //头指针cursor 指向这个新插入的节点
			L[1].cursor = 0;               //置链尾标志
		}
		else
		{
			k = j + 1;
			while (k != j)                 //在数组中循环查找存放x 的位置
			{
				if (L[k].cursor == -1)     //找到空位置
				{
					break;
				}
				else
				{
					k = (k + 1) % MAXSIZE;  //否则查找下一个位置
				}
			}
			if (k != j)                     //在数组中找到一个空位置来存放x
			{
				L[k].data = x;
				L[k].cursor = L[0].cursor;  //将其插入到静态链表表头
				L[0].cursor = k;
			}
			else
			{
				printf("List overflow!\n"); //链表已满无法插入
			}
		}
	}
	else                                    //i != 1 不是作为第一个节点插入
	{
		k = 0;	
		while (k < i - 2 && j != 0)         //查找第i-1 个节点, j 不等于0 则表示
		{
			k++;
			j = L[j].cursor;
		}

		if (0 == j)        //查完整个静态链表未找到第i-1 个节点,即链表长度小于i-1 个节点
		{
			printf("Insert error\n");
		}
		else
		{
			j1 = j;                         //找到第i-1 个节点
			j2 = L[j].cursor;     //用j2 保存原L[j].cursor 值,此值为第i个节点的位置值
			k = j + 1;
			while (k != j)                  //在数组中循环查找存放x 的位置
			{
				if (L[k].cursor == -1)      //找到空位置
				{
					break;
				}
				else
				{
					k = (k + 1) % MAXSIZE;  //否则查找下一个位置
				}
			}

			if (k != j)                     //在数组中找到一个空位置来存放x
			{
				L[k].data = x;
				L[j1].cursor = k;           //作为第i 个节点链入倒静态链表
				L[k].cursor = j2;           //新节点之后再链接上原第i 个节点
			}
			else
			{
				printf("List overflow!\n"); //链表已满,无法插入
			}
		}

	}
}

void print(SNode *L)
{
	int i;
	i = L[0].cursor;                        //从静态链表的表头元素开始输出
	while (i != 0)
	{
		printf("%c ", L[i].data);
		i = L[i].cursor;
	}
	printf("\n");
}

int main()
{
	SNode L[MAXSIZE];
	int i;
	char x;
	for (i = 1; i < MAXSIZE; i++)           //静态链表初始化
	{
		L[i].cursor = -1;
	}
	L[0].cursor = 0;                        //静态链表初始为空标志(0 为链尾)
	i = 1;
	printf("Input element of llist\n");     //建立静态链表
	scanf("%c", &x);
	while (x != '\n')
	{
		InsertList(L, i, x);
		i++;
		scanf("%c", &x);
	}
	printf("Input site and element of insert\n");
	scanf("%d %c", &i, &x);                 //输入要插入元素的位置
	InsertList(L, i, x);                    //在静态链表中插入元素
	printf("Output list\n");
	print(L);                                //输出静态链表

	return 0;
}

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值