本节是建立在已能成功创建静态链表的基础上,因此我们继续使用上节中已建立好的静态链表学习本节内容,建立好的静态链表如图 1 所示:
????????????????????????????????????????????????????????????????????????图 1 建立好的静态链表
?
静态链表添加元素
例如,在图 1 的基础,将元素 4 添加到静态链表中的第 3 个位置上,实现过程如下:
- 从备用链表中摘除一个节点,用于存储元素 4;
- 找到表中第 2 个节点(添加位置的前一个节点,这里是数据元素 2),将元素 2 的游标赋值给新元素 4;
- 将元素 4 所在数组中的下标赋值给元素 2 的游标;
经过以上几步操作,数据元素 4 就成功地添加到了静态链表中,此时新的静态链表如图 2 所示:
????????????????????????????????????????????????????????????????????????图 2 添加元素 4 的静态链表
由此,我们通过尝试编写 C 语言程序实现以上操作。读者可参考一下程序:
//向链表中插入数据,body表示链表的头节点在数组中的位置,add表示要插入元素的位置,a‘表示要插入的数据
void insertArr(component* array, int body, int add, char a)
{
int tempBody = body;//tempBody做遍历结构体数组使用
//找到要插入位置的上一个节点在数组中的位置
for (int i = 1; i < add; i++) {
tempBody = array[tempBody].cur;
}
int insert = mallocArr(array);//申请空间,准备插入
array[insert].data = a;
array[insert].cur = array[tempBody].cur;//新插入节点的游标等于其直接前驱节点的游标
array[tempBody].cur = insert;//直接前驱节点的游标等于新插入节点所在数组中的下标
}
|