单链表创建-遍历-排序-插入-删除-逆序操作

2024-09-02 12:48

本文主要是介绍单链表创建-遍历-排序-插入-删除-逆序操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#include <iostream>
using namespace std;typedef struct NodeType
{int data;NodeType* pNext;
}NodeType;
//链表的1创建 2 遍历 3排序 4 插入 5 删除
NodeType* create_list();
void traverse_list(NodeType* pHead);
void sort_list(NodeType* pHead);
void insert_list(NodeType*,int pos,int val);
void delete_list(NodeType*,int pos);NodeType* reverse_list(NodeType* pHead);int main()
{NodeType* pHead=create_list();//insert_list(pHead,1,33);//traverse_list(pHead);//delete_list(pHead,1);pHead=reverse_list(pHead);traverse_list(pHead);return 0;
}
//*****************创建链表*************************************************/
NodeType* create_list()
{cout <<" 输入创建节点个数" <<endl;int len;int val;cin >> len;if (len<=0){exit(-1);}NodeType* pHead=new NodeType;NodeType* p=pHead;for (int i=0;i<len;i++){cin >>val;NodeType* pNew=new NodeType;pNew->data=val;pNew->pNext=NULL;p->pNext=pNew;p=pNew;}return pHead;
}
//*****************遍历链表*************************************************/
void traverse_list(NodeType* pHead)
{for (NodeType*p=pHead->pNext;p!=NULL;p=p->pNext){cout << p->data << " ";}cout << endl;
}
/*****************排序链表*************************************************/
void sort_list(NodeType* pHead)
{NodeType* p=pHead->pNext;NodeType* pTail;for (;p->pNext!=NULL;p=p->pNext){for (pTail=p->pNext;pTail!=NULL;pTail=pTail->pNext){if((p->data)>(pTail->data)){swap(p->data,pTail->data);}}}
}
/*****************插入链表*************************************************/
void insert_list(NodeType* pHead,int pos,int val)
{//不仅仅是判断条件,而且还有定位p(插入点位置前一个位置)NodeType* p=pHead;for (int i=0;p!=NULL&&i<pos-1;p=p->pNext){++i;}//插入 就插入一个节点NodeType* pNew=new NodeType;pNew->data=val;pNew->pNext=p->pNext;p->pNext=pNew;
}/*****************插入链表*************************************************/
void delete_list(NodeType* pHead,int pos)
{NodeType* p=pHead;for ( int i=0;i<pos-1&&p!=NULL;p=p->pNext,i++){}NodeType* q=p->pNext;p->pNext=p->pNext->pNext;delete q;}
/*****************逆序链表*************************************************/
NodeType* reverse_list(NodeType* pHead)
{NodeType* p1,*p2,*p3;if (pHead==NULL||pHead->pNext==NULL){return pHead;}p1=pHead->pNext;p2=p1->pNext;p1->pNext=NULL;while (p2){p3=p2->pNext;p2->pNext=p1;p1=p2;p2=p3;}pHead->pNext=p1;return pHead;
}

逆序链表笔记图:


这篇关于单链表创建-遍历-排序-插入-删除-逆序操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

macOS无效Launchpad图标轻松删除的4 种实用方法

《macOS无效Launchpad图标轻松删除的4种实用方法》mac中不在appstore上下载的应用经常在删除后它的图标还残留在launchpad中,并且长按图标也不会出现删除符号,下面解决这个问... 在 MACOS 上,Launchpad(也就是「启动台」)是一个便捷的 App 启动工具。但有时候,应

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

idea中创建新类时自动添加注释的实现

《idea中创建新类时自动添加注释的实现》在每次使用idea创建一个新类时,过了一段时间发现看不懂这个类是用来干嘛的,为了解决这个问题,我们可以设置在创建一个新类时自动添加注释,帮助我们理解这个类的用... 目录前言:详细操作:步骤一:点击上方的 文件(File),点击&nbmyHIgsp;设置(Setti

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

Python使用DrissionPage中ChromiumPage进行自动化网页操作

《Python使用DrissionPage中ChromiumPage进行自动化网页操作》DrissionPage作为一款轻量级且功能强大的浏览器自动化库,为开发者提供了丰富的功能支持,本文将使用Dri... 目录前言一、ChromiumPage基础操作1.初始化Drission 和 ChromiumPage

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件