news 2026/6/14 19:43:54

数据结构学习篇(5)---顺序表和链表的区别

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
数据结构学习篇(5)---顺序表和链表的区别

对于顺序表和链表的异同,上面这个表格直观展示了两者的不同之处,有几点可以做一下解释:顺序表和链表在逻辑结构上都是连续的,但是在物理结构,也就是存储空间上,顺序表是连续的,因为他的本质是数组,而链表是不连续的;其次在随机访问方面,顺序表是可以直接通过下标来访问其中的数据的,这个操作对应的时间复杂度为O(N),但是对于链表而言则无法进行这种操作,它是需要遍历其中的每一个节点才可以对数据进行访问,这就涉及到循环,所以对应的时间复杂度为O(N);对于两者在插入数据方面,链表是优于顺序表的,因为顺序表在进行扩容操作时,往往是按照原来容量的两倍进行操作,这就可能会导致空间过剩或空间不足,而当空间不足时又要进行下一次的空间扩容,这对时间和空间都会造成损耗,相对于链表而言就没有这一说,想要进行数据增加只需要增加相应节点即可,时间上得到了保证同时空间也不会产生浪费。

对于缓存利用率这点,则需要做一些扩展来进行解释:

这副图片直观展示了计算机存储数据的方式,其中对于寄存器而言,可以理解为是存储一些小的数据,而往下的三个高速储存器则是储存一些大的数据,当然这些数据都是经过缓存的,通常数据存储在内存当中,也就是L4;如果cpu要对数据进行处理,则需要先判断所需数据有没有被缓存,如果已经提前缓存好了,那么“缓存命中”,则可以直接对这些数据进行访问,如果没有进行缓存,说明“缓存不命中”,那么就要把数据从内存加载到缓存中,也就是前四级中,那么这个加载过程并不是对数据进行一个一个的缓存,而是缓存所需数据及其后面跟着的一块数据集,这些数据 的地址都是连续的,所以对于顺序表而言,因为其存储空间是连续的,所以cpu要对一个顺序表里面的数据进行访问时,能够先直接将一整块数据进行缓存然后进行访问,这样的话缓存利用率就很高,但是对于链表而言,因为它的存储空间并不连续,所以对里面的数据进行一整块缓存时,就会缓存一些不必要的数据而导致缓存污染,这也就说明链表的缓存利用率低。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/14 8:20:09

【Processing】读取并全屏显示、编辑图片模板

本文展示了两种在Processing中全屏显示图片的方法。第一种是基础实现,仅全屏显示图片;第二种增加了交互功能,包括局部像素处理(将特定位置像素改为绿色)和文字显示(通过按键切换"IP_ON"/"IP…

作者头像 李华
网站建设 2026/6/12 18:14:39

嵌入式5个“宝藏开源项目”复刻完,代码能力直接封神

嵌入式5个“宝藏开源项目”复刻完,代码能力直接封神 写代码时你是不是也遇到过这些“崩溃瞬间”? 驱动能写但架构建不出来,扩功能就得大改;代码凑活能跑,可复用性为零,后续维护堪比拆炸弹;啃完几…

作者头像 李华
网站建设 2026/6/14 16:53:41

WebSocket 实时聊天功能

在上一讲中,Spring Boot 后端实现 WebSocket 已创建过后端项目,现在开始补充前端 在项目下新增一个模块frontend【与后端src目录平级】 在前端目录下执行npm install 不看上一讲也可以,直接创建一个前后端项目即可,下面会给出完整…

作者头像 李华
网站建设 2026/6/10 12:08:21

蓝桥杯103 日期问题

题目链接:https://www.lanqiao.cn/problems/103/learning/ 前置知识 输入解析 要会什么? 会用这一句把 AA/BB/CC 读进来: int a,b,c; scanf("%d/%d/%d", &a, &b, &c); 要记住什么? "%d/%d/%d"…

作者头像 李华
网站建设 2026/6/15 5:03:01

leetcode解题方法

双指针法&#xff1a;适用于有序数组去重、两数之和等问题。通过左右指针减少时间复杂度至O(n)。示例代码&#xff1a;c复制插入int removeDuplicates(int* nums, int numsSize) {if (numsSize 0) return 0;int slow 0;for (int fast 1; fast < numsSize; fast) {if (num…

作者头像 李华
网站建设 2026/6/12 21:04:53

八)--工具和MCP调用

1. 工程结构概览Spring AI 提供了完整的工具调用&#xff08;Tool Calling&#xff09;能力&#xff0c;让 AI 模型可以调用外部服务。同时&#xff0c;Spring AI 还支持 MCP&#xff08;Model Context Protocol&#xff09;&#xff0c;这是一个标准化的工具协议。spring-ai-m…

作者头像 李华