一、头文件中:定义结构体、功能函数
在头文件中定义结构体,用typedef进行重定义
二、实现功能函数
1、初始化函数
2、实现插入函数
一般分为3个步骤:
第一步:在堆内存中购买新节点。通过malloc动态开辟内存实现,每次开辟一个节点,因此只需要malloc( 1 * sizeof (struct Node))
第二步:寻找合适的位置进行插入值即可。头插、尾插、按位置插入的代码的区别点主要在于寻找合适位置。
头插:不用寻找位置,在头节点后的第一个有效节点位置,即所需要插入的位置
尾插:需要通过for(struct Node* p = Pn ; p -> next != NULL ;p = p -> next )循环来找到最后一位的位置
按位置插:(index == 0表示头插)最重要的是要通过for(int i= 0 ; i<index ;i++)循环来找到待插入结点的上一位节点p位置,找到p之后,p—>next这个地址就是待插入的位置
第三步:插入。举例:在A——>B两条线中插入C(新节点),那就得先让C——>B,然后再断开A指向B,让A——>C即可。这里不能先断开AB中间的线,否则就找不到B。
固定表达式:
Pnewnode -> next = Pn ->next;
Pn ->next =Pnewnode;
代码实现:
1、头插
2、尾插
3、按位置插
3、实现删除函数
删除节点一般要对单链表进行判空,然后需要两个指针,分别指向待删除节点(p)和待删除节点的上一个节点(q)
p指向待删除结点,对于头删除而言,待删除结点就是头结点的next域
q指向待删除结点的上一个结点地址,对于头删除而言,q即为头结点
代码实现:
1、头删除
2、尾删除
3、按位置删除(index == 0就是头删)
4、按值删除
按值删除这里,一般需要先调用search函数,判断单链表中是否存在待删除节点
4、实现查找函数
5、实现判空操作
6、获取有效值个数(逻辑上理解为长度,实际是节点数)
7、清空函数
8、销毁函数两种方案
销毁1——无限头删:
销毁2——不借助头结点,需要两个临时指针p和q
9、实现打印函数
10、代码测试
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
#include"list.h"
int main() {
struct Node Pn;
init(&Pn);
for (int i = 0; i < 10; i++) {
insert_index(&Pn, i + 1, i);
}
Show(&Pn);
printf("Get_length = %d\n", Get_length(&Pn));
insert_head(&Pn,100);
Show(&Pn);
printf("Get_length = %d\n", Get_length(&Pn));
insert_tail(&Pn, 100);
Show(&Pn);
printf("Get_length = %d\n", Get_length(&Pn));
printf("------------------------\n");
remove_head(&Pn);
Show(&Pn);
printf("Get_length = %d\n", Get_length(&Pn));
remove_tail(&Pn);
Show(&Pn);
printf("Get_length = %d\n", Get_length(&Pn));
remove_index(&Pn,5);
Show(&Pn);
printf("Get_length = %d\n", Get_length(&Pn));
remove_value(&Pn, 5);
Show(&Pn);
printf("Get_length = %d\n", Get_length(&Pn));
printf("------------------------\n");
destory1(&Pn);
return 0;
}