【数据结构】单链表

一、头文件中:定义结构体、功能函数

        在头文件中定义结构体,用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;
}

  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值