单链表(不带头结点)

不带头结点的节点因为插入删除的时候会改变或者删除第一个节点,所以要引入二级指针进行一系列的操作


头文件

#pragma once
//不带头结点的单链表
typedef struct Node
{int data;//数据Node * next;//存放下一个元素的地址
}Node;
//初始化
void InitList(Node **ps);
//头插
bool Insert_Head(Node **ps,int val);
//尾插
bool Insert_Tail(Node **ps,int val);
//按位置插入
bool Insert_Pos(Node **ps,int pos,int val);
//删除某个节点
bool Delete_Node(Node **ps,int key);
//删除整个链表
bool Delete_List(Node **ps);
//查找
Node *Search(Node *ps,int key);
//链表长度
int GetLength(Node *ps);
//打印链表的值
void Show(Node* ps);

cpp文件

#include<iostream>
#include<assert.h>
#include"NoList.h"
using namespace std;void InitList(Node* *ps)
{assert(ps != NULL);*ps = NULL;
}static Node* BuyNode(int val)
{Node *pnewnode = new Node();pnewnode->data = val;pnewnode->next = NULL;return pnewnode;
}
bool Insert_Head(Node* *ps,int val)
{assert(ps != NULL);Node* pnewnode = BuyNode(val);pnewnode->next = *ps;*ps = pnewnode;return true;
}bool Insert_Tail(Node* *ps,int val)
{assert(ps != NULL);Node* pnewnode = BuyNode(val);Node* pTail = *ps;if(pTail == NULL){*ps = pnewnode;//}else{	while(pTail->next != NULL){pTail = pTail->next;}pTail->next = pnewnode;}return true;
}bool Insert_Pos(Node* *ps,int pos,int val)
{assert(ps != NULL);Node * q = *ps;for(int i = 0;i<pos;i++){q = q->next;}Node *p =BuyNode(val);p->next = q->next;q->next = p;return true;
}bool Delete_Node(Node* *ps,int key)
{assert(ps != NULL);Node* p = Search(*ps,key);if(p == NULL){return false;}//删除的节点是第一个节点也是最后一个节点if(p == *ps){delete p;p = NULL;/ps = NULL;/}//删除的节点不是尾结点else if(p->next != NULL){Node * q = p->next;p->data = q->data;p->next = q->next;delete q;q = NULL;}//节点有很多,删除的节点是尾结点else if(p ->next == NULL){Node* q = *ps;for(;q->next!= NULL;q = q->next);/*q ->next = NULL;q->next ->data = NULL;delete (q->next);*/q ->next = NULL;delete (q->next);p = NULL;}return true;
}bool Delete_List(Node* *ps)
{assert(ps != NULL);Node* p;//Node* q = p;while(*ps != NULL){p = *ps;*ps = p->next;delete p;}return true;
}Node* Search(Node* ps,int key)
{assert(ps != NULL);Node * q  = ps;while(q != NULL){if(key == q->data){return q;}q = q->next;}return NULL;
}int GetLength(Node *ps)
{assert(ps != NULL);int length = 0;for(Node* q = ps;q!= NULL;q = q->next){length++;}return length;
}void Show(Node* ps)
{for(Node *q = ps;q!= NULL;q= q->next){cout << q->data << " " ;}cout <<endl;
}

主函数

#include<iostream>
#include<assert.h>
#include"NoList.h"
using namespace std;int main()
{Node* head;InitList(&head);/*for(int i = 0;i<10;i++){Insert_Head(&head,i);}*/for(int i = 0;i<10;i++){Insert_Tail(&head,i,i);}Show(*&head);cout << GetLength(head) << endl;Insert_Pos(&head,5,111);Show(*&head);cout << GetLength(head) << endl;Delete_Node(&head,5);Show(head);cout << GetLength(head) << endl;Delete_List(&head);Show(head);return 0;
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/526107.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

flink checkpoint 恢复_干货:Flink+Kafka 0.11端到端精确一次处理语义实现

2017年12月Apache Flink社区发布了1.4版本。该版本正式引入了一个里程碑式的功能&#xff1a;两阶段提交Sink&#xff0c;即TwoPhaseCommitSinkFunction。该SinkFunction提取并封装了两阶段提交协议中的公共逻辑&#xff0c;自此Flink搭配特定source和sink(特别是0.11版本Kafka…

8255数码管显示0到9_汇编语言--键盘扫描及显示实验(含代码解释)

实验题目将8255单元与键盘及数码管显示单元连接&#xff0c;编写实验程序&#xff0c;扫描键盘输入&#xff0c;并将扫描结果送数码管显示。键盘采用4X4键盘,每个数码管显示值可为0-F共16个数。实验具体内容如下:将键盘进行编号&#xff0c;记作0~F,当按下其中一一个按键时&…

printf函数输出多个printf 、前置加加或者后置加加

目录 &#xff08;1&#xff09;前置加加和后置加加的区别 &#xff08;2&#xff09;printf输出前置加加 &#xff08;3&#xff09;printf输出后置加加 &#xff08;4&#xff09;printf输出printf &#xff08;1&#xff09;前置加加和后置加加的区别 首先我们先来了解…

python怎么执行csv文件_无法读取/打开/或对CSV文件python 3.4windows执行任何操作

我无法打开程序生成的任何CSV文件(我没有程序的完整详细信息)&#xff0c;它的文件名为266925.130314-88850999.word文件是csv&#xff0c;它在excel 2013中打开&#xff0c;所有编辑器都很好&#xff0c;我尝试用原始文件名打开&#xff0c;我尝试通过将扩展名从.word更改为.c…

strlen函数strcpy函数strcat函数的实现

一、strlen函数 作用&#xff1a;计算字符串第一次碰到\0的长度&#xff0c;不包含\0。 #include<stdio.h> #include<assert.h>int Strlen(const char * str)//const的作用是不改变str字符数组 {assert(str ! NULL);if(str NULL){return NULL;}int length 0;//…

mysql 生明变量_mysql中变量的使用

4.4.1 局部变量局部变量是用户可自定义的变量&#xff0c;它的作用范围仅在程序内部。在程序中通常用来储存从表中查询到的数据&#xff0c;或当作程序执行过程中暂存变量使用。局部变量必须以“”开头&#xff0c;而且必须先用DECLARE命令说明后才可使用。其说明形式如下&…

斐波那契数列 青蛙跳台阶 变态跳台阶

目录 一、斐波那契数列 二、青蛙跳台阶问题 三、变态跳台阶 一、斐波那契数列 题目&#xff1a;写一个函数&#xff0c;输入n&#xff0c;求斐波那契数列的第n项。 思路&#xff1a;用递归的方法&#xff0c;f(n) f(n-1) f(n-2)。代码比较简单。 #include<iostream&g…

python history函数_python的history_n 和history函数 获取的成交量和持仓量出现翻倍

使用的最新的掘金者3。用python sdk调用 history_n 和history函数获取日k线&#xff0c;出现有的活约交易日的成交量和持仓量翻倍了,有的日期又是正确的。比如动力煤 ZC2001 对应代码CZCE.ZC001&#xff0c;获取 2019-05-20 这天的日线数据出现翻倍交易量是 2464.000000持仓量 …

math python 向上取整_计算机等级考试二级Python语言模拟试卷单选解答详解第1期...

模拟试卷单选题20题有粉丝私信希望增加一些针对国家二级Python考级的小练习和答题详解。所以就有了模拟试卷的题目讲解。第1题&#xff1a;下面的程序运行结果是&#xff08; &#xff09;解答&#xff1a;这是一个变量作用域的问题&#xff0c;变量分为全局变量和局部变量。a1…

将字符转换成数字(atoi),将数字转换成字符(itoa)

目录 一、将字符转换为数字。 二、将数字转换成字符。 一、将字符转换为数字。 &#xff08;首先字符必须是"0" —"9"&#xff0c;然后转换成十进制的数字&#xff09; 比如将"1234" 转换成 1234 #include<stdio.h> #include<st…

visio2013复制到word有多余白边_学习工坊(一)|实用技巧之Word篇

Word那些你不知道的实用小技巧让你工作更快捷大家无论学习还是工作总离不开Word软件吧今天推给大家几个实用的Word小技巧从此快人一步开启Word新世界1、Word的分屏在编辑Word文字的时候有时候需要对照前后文但是一直上下翻找是否会感觉很麻烦这里悄悄告诉大家Word可以分屏哦我们…

san分布式共享文件系统_SAN网络存储共享软件全攻略剖析

在高性能专用存储网络需求的驱使下&#xff0c;SAN存储区域网络系统大量应用于高性能计算网络系统、大型网站系统、非线性编辑系统等网络系统中&#xff0c;存储设备与计算机主机系统之间一对一的关系&#xff0c;被可供多个系统共享同一个存储设备网络的关系所取代。为确保多大…

怎么看调用的接口_SpringCloud服务间调用

本篇简介在上一篇我们介绍了SpringCloud中的注册中心组件Eureka。Eureka的作用是做服务注册与发现的&#xff0c;目的是让不同的服务与服务之间都可以通过注册中心进行间接关联&#xff0c;并且可以通过注册中心有效的管理不同服务与服务的运行状态。但在微服务的架构中&#x…

bimmercode刷隐藏教程_PS教程:快速提取人物像素,制作人物海报主体,简单易学...

这一篇主要是教大家快速提取人物像素&#xff0c;制作人物海报主体。主要是用快速复制移动快捷键(alt方向键)、单列框选工具、变形工具进行操作&#xff0c;简单快速。人物素材通过抠图得到&#xff0c;抠图方法用的是快速选择工具选择并遮住&#xff0c;这里就不说具体了&…

cass生成曲线要素文件_《CASS道路断面法施工技术》

技术分享&#xff0c;研究很久&#xff0c;分享一套CASS处理道路断面的施工方法技术&#xff0c;不懂的欢迎留言。CASS应用于道路类工程计算/ 1 /绘制道路中线道路中线一般由直线、圆曲线、缓和曲线段组成的复合线。CASS软件我们使用菜单中“公路曲线设计”生成。1、录入要素文…

dnf机械机器人补丁_干货 | 详解工业机器人控制系统架构

机械臂和移动机器人两种工业机器人的特点你知道吗&#xff1f;下面我们对比一下二者的控制系统方案。以上分类是根据应用对象&#xff0c;此外&#xff0c;市面上更多的是通用型运动控制器&#xff0c;即控制非标设备的。1 控制器底层方案1.1 机械臂类机械臂类的控制器发展较…

项目的ar指什么_AR眼镜显示测评标准解读——概述

AR眼镜检测哪些AR眼镜作为近眼显示设备的一种&#xff0c;运用其显示系统实现了虚拟信息与真实世界相叠加的效果&#xff1b;AR眼镜显示性能指标影响着AR产品实际的体验效果。因此&#xff0c;如何客观评价AR眼镜显示技术指标尤为重要。AR眼镜的性能特征和技术参数主要包括光学…

我的JAVA

一、了解Java Java是一门重编译语言&#xff0c;它本身就包含了许多类库、特性&#xff0c;再加上它所衍生出来的相关产品&#xff0c;是一个很庞大的语言体系&#xff0c;拥有无数分支&#xff0c;核心是JDK和JRE。 JDK&#xff0c;英文全称是Java Development Kit&#xff0c…

11下滑半个屏幕_努比亚发布手表手机:柔性屏幕,体积感人

2月26日凌晨&#xff0c;努比亚在MWC2019展会上召开新品发布会&#xff0c;全新的柔性屏“腕机”努比亚α正式与我们见面。努比亚α采用一块960*192分辨率的4英寸柔性屏&#xff0c;视野比手表类产品更广阔。同时为了让弯折的过程中不易出现起皱等问题&#xff0c;努比亚还使用…

Java-02

JAVA工作方式 源程序(myProgram.java) – > 编译(javac myProgram.java) -> JAVA字节码(myProgram.class) ->运行(java myProgram) 指令&#xff1a; 编译时&#xff1a;javac(compiler) 文件名运行时&#xff1a;java 文件名 JAVA的程序结构 源文件>类>方法&…