无头单链表基本操作的实现

2024-02-25 19:58

本文主要是介绍无头单链表基本操作的实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先 . 看一下我们要实现的基本功能;,实现以下链表的基本操作

typedef int DataType;

typedef struct Node
{
struct Node* _pNext;
DataType _data;
}Node, *PNode;


//不带头结点的单链表//
// .h
// 链表初始化
void SListInit(PNode* pHead);

// 尾插
void SListPushBack(PNode* pHead, DataType data);

// 尾删
void SListPopBack(PNode* pHead);

// 头插
void SListPushFront(PNode* pHead, DataType data);

// 头删
void SListPopFront(PNode* pHead);

// 查找值为data的结点,返回该结点在链表中的位置
PNode SListFind(PNode pHead, DataType data);

// 在链表pos位置后插入结点data
void SListInsert(PNode* pHead, PNode pos, DataType data);

// 删除链表pos位置上的结点
void SListErase(PNode* pHead, PNode pos);

// 销毁单链表
void SListDestroy(PNode* pHead);

// 求链表中结点的个数
int SListSize(PNode pHead);

// 将链表中的结点清空
void SListClear(PNode* pHead);

// 获取结点
PNode BuySListNode(DataType data);

// 获取链表中的最后一个结点,返回该结点的地址
PNode SListBack(PNode pHead);

///
然后在.h中声明要实现的功能:看代码:

#include<assert.h>
#include<stdio.h>
typedef int DataType;typedef struct Node
{struct Node* _pNext;DataType _data;
}Node, *PNode;//不带头结点的单链表// 
// .h 
// 链表初始化 
void SListInit(PNode* ppHead);//新节点的申请
PNode NewNode(DataType data);// 尾插 
void SListPushBack(PNode* ppHead, DataType data);// 尾删 
void SListPopBack(PNode* ppHead);// 头插 
void SListPushFront(PNode* ppHead, DataType data);// 头删 
void SListPopFront(PNode* ppHead);// 查找值为data的结点,返回该结点在链表中的位置 
PNode SListFind(PNode pHead, DataType data);// 在链表pos位置后插入结点data 
void SListInsert(PNode* ppHead, PNode pos, DataType data);// 删除链表pos位置上的结点 
void SListErase(PNode* ppHead, PNode pos);// 销毁单链表 
void SListDestroy(PNode* ppHead);// 求链表中结点的个数 
int SListSize(PNode pHead);// 将链表中的结点清空 
void SListClear(PNode* ppHead);// 获取结点 
PNode BuySListNode(DataType data);// 获取链表中的最后一个结点,返回该结点的地址 
PNode SListBack(PNode pHead);

然后在.c文件中来实现这波功能:

#define _CRT_SECURE_NO_WARNINGS 
#include "标头.h";
void SListInit(PNode* ppHead){// 链表初始化assert(ppHead);*ppHead = NULL;
}
//新节点的申请
PNode NewNode(DataType data){PNode PNewnode = (PNode)malloc(sizeof(Node));if (NULL == PNewnode){return NULL;}PNewnode->_pNext = NULL;PNewnode->_data = data;return PNewnode;
}
// 尾插 
void SListPushBack(PNode* ppHead, DataType data){assert(ppHead);PNode pnewnode = NULL;pnewnode = NewNode(data);if (NULL == pnewnode){return NULL;}if (NULL == *ppHead){*ppHead = pnewnode;}else{PNode pcurnode = *ppHead;while (pcurnode->_pNext != NULL){pcurnode = pcurnode->_pNext;}pcurnode->_pNext = pnewnode;}
}
// 尾删 
void SListPopBack(PNode* ppHead){assert(ppHead);if (NULL == *ppHead){return NULL;}else if ((*ppHead)->_pNext == NULL){free(*ppHead);*ppHead = NULL;}else{PNode pcurnode = *ppHead;while (NULL != pcurnode->_pNext->_pNext){pcurnode = pcurnode->_pNext;}free(pcurnode->_pNext);pcurnode = NULL;}
}
// 头插 
void SListPushFront(PNode* ppHead, DataType data){assert(ppHead);PNode pnewnode = NULL;pnewnode = NewNode(data);if (NULL == pnewnode){return NULL;}pnewnode->_pNext = *ppHead;*ppHead = pnewnode;
}
// 头删 
void SListPopFront(PNode* ppHead){assert(ppHead);if (NULL == *ppHead){return NULL;}else{DataType deldata = *ppHead;*ppHead = (*ppHead)->_pNext;free(deldata);}}
// 查找值为data的结点,返回该结点在链表中的位置 
PNode SListFind(PNode pHead, DataType data){if (NULL == pHead){return NULL;}PNode pcurnode = NULL;while (pcurnode!=NULL){if (pcurnode->_data == data){return pcurnode;}}return NULL;
}
// 在链表pos位置后插入结点data 
void SListInsert(PNode* ppHead, PNode pos, DataType data){assert(ppHead);if (*ppHead == NULL || pos == NULL){return;}PNode pnewnode = NULL;pnewnode = NewNode(data);if (NULL == pnewnode){return NULL;}pnewnode->_pNext = pos->_pNext;pos->_pNext = pnewnode;}
// 删除链表pos位置上的结点 
void SListErase(PNode* ppHead, PNode pos){assert(ppHead);if (*ppHead == NULL || pos == NULL){return;}if (pos == *ppHead){SListPopFront(ppHead);}else{PNode pcurnode = *ppHead;while (pcurnode->_pNext != pos){pcurnode = pcurnode->_pNext;}pcurnode->_pNext = pos->_pNext;free(pos);}
}
// 销毁单链表 
void SListDestroy(PNode* ppHead){PNode pdelnode = NULL;assert(ppHead);while (*ppHead){pdelnode = *ppHead;*ppHead = (*ppHead)->_pNext;free(pdelnode);}
}
// 求链表中结点的个数 
int SListSize(PNode pHead){PNode pcurnode = pHead;int count = 0;while(pcurnode){count++;pcurnode = pcurnode->_pNext;}return count;
}
// 将链表中的结点清空 
void SListClear(PNode* ppHead){SListDestroy(ppHead);
}

然后,就可以写一个test.c文件来测这波功能啦(可以开个监视窗口来检测一下是否正确

这篇关于无头单链表基本操作的实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/746543

相关文章

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核