初识链表(7.25)

前面我们学习了顺序表,但顺序表其实存在一些问题

1. 中间/头部的插入删除,时间复杂度为O(N)

2. 增容需要申请新空间,拷贝数据,释放旧空间。会有不小的消耗(尤其是异地扩容)。
3. 增容一般是呈2倍的增长,势必会有一定的空间浪费。例如当前容量为100,满了以后增容到 200,我们再继续插入了5个数据,后面没有数据插入了,那么就浪费了95个数据空间。

 优点:

1.尾插尾删足够快

2.下标的随机访问和修改

如何改善顺序表的这些问题呢?那么看看远处的链表吧

3.1 链表的概念及结构
概念:链表是一种 物理存储结构上非连续 、非顺序的存储结构,数据元素的 逻辑顺序 是通过链表中的 指针链接 次序实现的 。

链表在内存中是什么样的呢?
以往在数组中内存空间是连续的,通过一个指针和 size 就能够找到并管理所有值;

在链表中的空间是多段不连续的,空间之间也没有大小关系,链表也定义一个头指针指向第一个空间,第一个空间中存放一个指针指向第二个空间,每个空间都有一个指针指向下一个空间,而最后一个空间的指针指向NULL(空)

形如:

物理形态:(箭头是臆想的)

 节点的空间是从堆上随机申请的,两次申请的空间可能连续,可能不连续。

3.2 链表的初步实现

初级单向链表举例:

//single link table
typedef int SLTDateType;
typedef struct SListNode //(链表节点)
{//数据SLTDateType data;//结构体类型的指针,能够找到下一个结构(节点)SLTDateType* next;
}SLTNode;//将结构体简写,等同于下一行
//typedef struct SListNode SLTNode;//打印链表
void PrintSList(SLTNode* phead)
{//拷贝头指针SLTNode* cur = phead;while (cur!=NULL){printf("%d ", cur->data);//指针指向节点中的下一个节点的地址cur = cur->next;}printf("NULL\n");
}
int main()
{//插入节点SLTNode* p1 = (SLTNode*)malloc(sizeof(SLTNode));p1->data = 10;SLTNode* p2 = (SLTNode*)malloc(sizeof(SLTNode));p2->data = 20;SLTNode* p3 = (SLTNode*)malloc(sizeof(SLTNode));p3->data =30;//让上一个节点指向下一个节点p1->next = p2;p2->next = p3;p3->next = NULL;PrintSList(p1);return 0;
}

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

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

相关文章

项目_数据可视化| 折线图.散点图.随机漫步

安装matplotlib 在正式开始编写程序之前,需要先安装pip、matplotlib模块,苹果系统的安装问题在之前的文章中有相关介绍内容,如果pycharm运行模块报错,可以再次检查是否版本兼容问题。 绘制折线图 调用subplot(&#x…

系统03:15min导图复习 文件管理

🐳前言 图源:文心一格 考研笔记整理,纯复习向,思维导图基本就是全部内容了,不会涉及较深的知识点~~🥝🥝 第1版:查资料、画思维导图~🧩🧩 编辑: …

unity操作_Camera c#

观察场景中Main Camera 的清除背景Clear Flags 第一种:Skybox天空盒渲染 制作3D游戏使用 第二种:Solid Color 制作2D游戏 第三种:Depth only 多个摄像机叠加渲染 相对重点学会多个摄像机设置Depth only使…

10.07hw

int main() {string str;cout << "输入字符串:";getline(cin,str);int size str.size();int big 0;int small 0;int num 0;int space 0;int other 0;for(int i0;i<size;i){if(str[i]<Z&&str[i]>A){big;}else if(str[i]<z&&st…

YOLOv5入门实践(1)— 基础环境介绍及搭建

前言&#xff1a;Hello大家好&#xff0c;我是小哥谈。YOLOv5基础知识入门系列和YOLOv5源码中的参数超详细解析系列学习完成之后&#xff0c;接着就进入YOLOv5入门实践系列了。为了让大家能够清楚地了解如何用YOLOv5去进行实践&#xff0c;本篇文章就简单给大家介绍一下YOLOv5基…

Leetcode901-股票价格跨度

一、前言 本题基于leetcode901股票价格趋势这道题&#xff0c;说一下通过java解决的一些方法。并且解释一下笔者写这道题之前的想法和一些自己遇到的错误。需要注意的是&#xff0c;该题最多调用 next 方法 10^4 次,一般出现该提示说明需要注意时间复杂度。 二、解决思路 ①…

记录本地部署Stable-diffusion所依赖的repositories和一些插件

今天按照其他文章的步骤拉取好了https://github.com/AUTOMATIC1111/stable-diffusion-webui后&#xff0c;点击webui-user.bat后发现&#xff0c;repositories和models还得慢慢拉取&#xff0c;好吧&#xff0c;GitHub Desktop&#xff0c;启动&#xff01; BLIP: https://git…

【论文极速读】EMT——评估多模态LLM中的灾难性遗忘问题

【论文极速读】EMT——评估多模态LLM中的灾难性遗忘问题 FesianXu 20231001 at Baidu Search Team 前言 论文[1]报告了多模态LLM中遇到的灾难性遗忘问题&#xff0c;并且提出了一种评估其程度的方法EMT&#xff0c;本文简要介绍&#xff0c;希望对读者有所帮助。如有谬误请见谅…

从哈希表到红黑树:探讨 epoll 是如何管理事件的?

一、引言 在计算机领域&#xff0c;事件通知是一种重要的机制&#xff0c;用于监视和响应各种事件&#xff0c;例如网络连接、文件IO、定时器等。随着计算机应用变得越来越复杂&#xff0c;对于高性能事件通知机制的需求也越来越迫切。传统的事件通知机制可能存在效率低下的问…

[架构之路-232]:目标系统 - 纵向分层 - 操作系统 - 数据存储:文件系统存储方法汇总

目录 前言&#xff1a; 一、文件系统存储方法基本原理和常见应用案例&#xff1a; 二、Windows FAT文件系统 2.1 概述 三、Linux EXT文件系统 3.1 基本原理 3.2 索引节点表&#xff08;Inode Table&#xff09; 3.2.1 索引节点表层次结构 3.2.2 间接索引表的大小和表项…

Java卷上天,可以转行干什么?

小刚是某名企里的一位有5年经验的高级Java开发工程师&#xff0c;每天沉重的的工作让他疲惫不堪&#xff0c;让他萌生出想换工作的心理&#xff0c;但是转行其他工作他又不清楚该找什么样的工作 因为JAVA 这几年的更新实在是太太太……快了&#xff0c;JAVA 8 都还没用多久&am…

鄙视测试,理解测试,成为测试

首先&#xff0c;其实题主的问题还是很实诚的&#xff0c;我刚开始做测试的时候其实也是这个心态&#xff0c;想转开发&#xff0c;也学习了很多的语言&#xff0c;个人觉得这是职业危机感的表现&#xff0c;挺好的&#xff0c;也相信题主不管去做开发和测试都会去不断的学习和…