02-2.3.6 顺序表和链表的比较

喜欢《数据结构》部分笔记的小伙伴可以订阅专栏,今后还会不断更新。🧑‍💻
此外,《程序员必备技能》专栏和《程序员必备工具》专栏(该专栏暂未开设)日后会逐步更新,感兴趣的小伙伴可以点一下订阅、收藏、关注!🚀
谢谢大家!🙏

逻辑结构

不管是顺序表还是链表,都属于线性表,都是线性结构

物理结构/存储结构

顺序表采用了顺序存储的方式

  • 优点:支持随机存取、存储密度高
  • 缺点:大片连续空间分配不方便、改变容量不方便
    链表采用链式存储的方式
  • 优点:离散的小空间分配方便、改变容量方便
  • 缺点:不可随机存取、存储密度低(需要指针)

数据的运算/基本操作

复习回忆思路:创销、增删改查

顺序表:

  • 需要预分配大片连续空间
  • 若分配空间过小,之后不方便扩展容量
  • 若分配空间过大,则浪费内存资源
    链表:
  • 只需要分配一个头结点(也可以不要头结点,只声明一个头指针),之后方便扩展
    如果我们的线性表采用
  • 静态分配:静态数组。那么容量不可改变
  • 动态分配:动态数组。即便使用malloc, free函数改变容量,但是需要移动大量元素,时间代价很高

链表:

  • free依次删除各个结点——手动回收空间
    顺序表:
  • 修改length = 0——系统自动回收空间

malloc申请的地址,是内存中的堆区,堆区不会由系统自动回收
所以在写代码的时候mallocfree必须成对出现

增、删

顺序表:

  • 插入/删除元素要将后续的元素都后移/前移
  • 时间复杂度: O ( n ) O(n) O(n),时间开销主要来自移动元素
  • 如果数据元素很大,则移动的时间代价很高
    链表:
  • 插入/删除元素只需要修改指针即可
  • 时间复杂度: O ( n ) O(n) O(n),时间开销主要来自查找目标元素
  • 查找元素的时间代价更低

顺序表:

  • 按位查找: O ( 1 ) O(1) O(1)
  • 按值查找: O ( n ) O(n) O(n),若表内元素有序,可在 O ( l o g 2 n ) O(log_2 n) O(log2n)时间内找到(如二分查找*)
    链表:
  • 按位查找: O ( n ) O(n) O(n)
  • 按值查找: O ( n ) O(n) O(n)

如何抉择?

表长难以估计、经常要增加/删除元素————链表
表长可预估、查询(搜索)操作较多————顺序表

知识回顾

开放式问题的回答思路:

  • 可以先探讨逻辑结构
  • 再讨论存储结构
  • 然后再探讨一些比较重要的基本操作的实现效率
  • 最后得出结论

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

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

相关文章

Linux系统进行DNS域名解析

文章目录 一、DNS1.1 DNS概述1.2 DNS的通俗解释1.3 域名的体系结构1.4 DNS解析的参数 1.5 DNS域名解析的过程 二、如何实现DNS(内网)2.1 DNS正向解析2.2 DNS反向解析2.3 主从DNS 一、DNS 1.1 DNS概述 DNS :Domain Name System,是域名系统的简称&#x…

Flutter Bloc之简单记录

目录 0.库安装 1.插件和自动生成 2.状态的配置 1.初始化中: 2.赋值完成后: 3.如果出错: 3.事件的配置 1.定义一个读取事件 2.定义一个更改事件 4.Bloc的设置 5.Bloc的使用 1.BlocProvider 2.内部调用 参考文章进行类的配置 0.库…

NSS题目练习7

[MoeCTF 2022]baby_file 打开看见一串源代码,需要get传参传入file 题目提示php伪协议 用dirsearch扫描发现flag.php 用php伪协议查看,回显一串base64编码 解码后得到flag [鹤城杯 2021]Middle magic 读取这两个文件 一个php正则表达式 补充&#xff1a…

解锁ArrayBlockingQueue奥秘:深入源码的精彩之旅

1.简介 ArrayBlockingQueue 是 BlockingQueue 接口的一个实现类,它基于数组实现了一个有界阻塞队列。创建 ArrayBlockingQueue 实例时需要指定队列的容量,队列的大小是固定的,无法动态增长。 主要特点包括: 有界性:A…

anaconda 多环境配置

1、查看所有的环境 conda info --envs 2、创建新的环境如python 3.10版本,-n 是name 的简写 conda create -n py3.10 python3.10 3、激活3.10环境 conda activate py3.10 4、退出当前环境 conda deactivate

sentaurus报错记录1

设置(sde:set-process-up-direction "0") 或者(sde:set-process-up-direction "z") 运行后报错 sde:set-process-up-direction: wrong argument type string (expected integer) 可能原因:版本问题导致,注释掉后运行结果正常

空对象模式

空对象模式 空对象模式(Null Object Pattern)是一种设计模式,用于解决在某些情况下不需要实例化具体的对象,而是返回一个“空”对象,这样可以简化代码、避免 NullPointerException 和提高程序的可读性和维护性。简单来说,”空对象模式“就是本该返回None值或抛出异常时,…

STM32——hal_SPI_(介绍)

SPI(串行外围设备接口)是一种高速的、全双工、同步的通信协议,通常用于短距离通信,尤其是在嵌入式系统中与各种外围设备进行通信。SPI接口由摩托罗拉公司推出,由于其简单和灵活的特性,它被广泛用于多种应用…

2023年计算机图形学课程知识总结

去年就该写的,但是去年这个时候太忙了。 就写来自己看看。留个记录留个念 文章目录 1. 图形,图像的定义2. 点阵、矢量3. 走样,反走样4. 字符裁剪精度(1) 串精度(2) 字符精度(3&…

外界的声音都是参考,你不开心就不要参考

在纷繁复杂的世界中,我们每天都会接收到来自四面八方的声音和建议。这些声音可能来自家人、朋友、同事,甚至是社交媒体上的陌生人。然而,在这众多的声音中,我们如何找到自己的方向,保持内心的平静和快乐呢?…

SpringBoot打war包并配置外部Tomcat运行

简介 由于其他原因,我们需要使用SpringBoot打成war包放在外部的Tomcat中运行,本文就以一个案例来说明从SpringBoot打war包到Tomcat配置并运行的全流程经过 环境 SpringBoot 2.6.15 Tomcat 8.5.100 JDK 1.8.0_281 Windows 正文 一、SpringBoot配置打war包 第一步&a…

手机兼职骗局花样多,5款常见骗局!

手机兼职骗局花样繁多,以下是五个常见的手机兼职骗局: 1. 打字骗局:如快递录入兼职、陪聊兼职等,这些兼职通常通过免费、高收入等诱惑吸引求职者。一旦求职者上钩,骗子会要求缴纳保证金、入会费等,最终求职…

J-Lin烧录

1、J-linK介绍 J-Link是由德国SEGGER公司推出的,主要用于支持仿真ARM内核芯片的JTAG仿真器。它支持JTAG和SWD两种模式,可以配合多种集成开发环境(如IAR EWAR, ADS, KEIL, WINARM, RealView等)使用,支持ARM7/ARM9/ARM…

odoo16 档案管理

档案管理,odoo15升级至odoo16完善 电子档案管理是指将传统纸质档案数字化,以便更加方便、快捷、安全地进行档案管理。电子档案管理系统可以对档案进行数字化、存储、检索、共享、传递和销毁等操作,从而提高了档案管理的效率和准确性&#xf…

使用cesiumLab使shp转为3dtlies

过程不做赘述,网上大把,说下注意事项。 1. 存储3DTiles 选项 若是打开则输出的文件为glb格式文件,因为glb文件好储存易传输跨平台。cesium可以使用但无法处理,例如改变颜色,改着色器等。若是不打开则输出的文件为bm3d格式文件,此…

Bond网卡

一、Bond网卡 1.1 Bond网卡概述 Bond网卡是指使用 Linux 系统中的 Bonding 技术创建的虚拟网络接口。 Bonding 技术允许将多个物理网卡(也称为接口或端口)绑定在一起,形成一个虚拟的网络接口,以增加网络带宽、提高网络容错性和…

表达式求值中的“整型提升”概念

一.基本原理和概念 如:代码 char a,b,c ; a b c ; 该代码在计算的时候就会先将 b 和 c 提升为 int 类型进行加法后,再将数据进行截断存放在内存存放变量 a 的空间中。 (1)提升和截…

删除临时表报ORA-14452错误解决方法

跑存储过程,里面有张临时表。跑完后打算删除临时表报ORA-14452:An attempt was made to create, alter or drop an index on te 跑存储过程,里面有张临时表。跑完后打算删除临时表报ora-14452:an attempt was made to create, alt…

眼底照 + OCT图 + 精神状态 ,预测阿尔兹海默症

眼底照片和OCT图像,预测阿尔兹海默症 数据多模态网络模型集成可视化分析 论文:https://www.ophthalmologyretina.org/action/showPdf?piiS2468-6530%2824%2900045-9 目前,认知障碍的诊断依赖于血清和蛋白质生物标志物的检测、脑脊液检查和正…

【教程】WordPress主题子比主题 添加私密评论功能

教程如下 打开子比主题的 functions.php 文件,在最后一个 ?> 的前面添加以下代码: //私密评论 function liao_private_message_hook( $comment_content , $comment){$comment_ID = $comment->comment_ID; $parent_ID = $comment->comment_parent; $parent_emai…