数据结构之【动态数组】

news/2024/9/22 14:33:43/

1. 线性表

概念:线性表是n个具有相同特性的数据元素的有限序列。

常见的线性表有:数组、链表、栈、队列、字符串……

特点:

  1. 保存在这个结构中的元素都是相同的数据类型。
  2. 元素之间线性排列,元素之间在逻辑上是连续的。

线性表最大的特点是有明确的索引下标的概念。

2. 动态数组

动态数组产生的由来:

由于原始数组存在定长问题,因此需要将原始数组进行扩充,将原始数组封装到一个类中,让他具备可扩展的能力。

对使用者而言,无需关心数组的长度问题,提供给用户的是一个动态数组,用户只需要使用提供的数组进行增删改查即可,无需关心数组越界问题

本质:将原始的数组封装到类中,对用户淡化数组长度的概念,当长度不够时,内部进行扩容操作。

动态数组=基本数组封装在类中+对外提供一系列的方便进行增删改查的方法。

(1) 为什么定义接口(定义线性表接口Seqlist)?

定义线性表的规范:一个类能称之为是线性表的子类,应该具备类似的行为(都是保存单个元素的集合,集合中元素的类型都是相同的,元素之间逻辑上连续)

定义接口的好处:可以以非常低的成本来更换具体的子类。

举例说明:

如果有一个动态数组类,实现增删改查方法,同时也有一个新的链表类,也具有增删改查的方法。对用户来说,则需要了解各个类的具体的增删改查方法,使用成本很高。

但是定义Seqlist线性表接口,数组、链表、字符串、栈、队列,只要是线性表接口的子类,均具有相同的方法,用户只需要了解接口中的方法类型,更换子类0成本


 


http://www.ppmy.cn/news/1124577.html

相关文章

德大黄鱼开捕 年产量20万吨 京东超市多举措保障黄鱼品质

作为“中国大黄鱼之都”,宁德大黄鱼占全国大黄鱼总产值产量均在90%以上。有关方面预计,今年全年宁德大黄鱼产量达20万吨,年增产10%,直接经济产值超百亿元。 宁德大黄鱼开捕活动,由宁德市政府、宁德渔业协会、京东超市…

Lua学习笔记:require非.lua拓展名的文件

前言 本篇在讲什么 Lua的require相关的内容 本篇需要什么 对Lua语法有简单认知 对C语法有简单认知 依赖Visual Studio工具 本篇的特色 具有全流程的图文教学 重实践,轻理论,快速上手 提供全流程的源码内容 ★提高阅读体验★ 👉 ♠…

算法与数据结构-堆

文章目录 什么是堆如何实现一个堆?如何基于堆实现排序?1. 建堆2. 排序 什么是堆 堆是一种特殊的树,特殊点有二,如下: 堆是一个完全二叉树;堆中每一个节点的值都必须大于等于(或小于等于&#…

SpringBoot 学习(九)Redis

11. 集成 Redis 11.1 说明 SpringBoot 操作数据:sping-data、jpa、jdbc、mongodb、redis SpringBoot 2. 后,jedis 被替换为 lettuce jedis:采用直连,多线程操作不安全,增强安全性需使用 jedis pool 连接池&#xff0…

如何编写测试用例,一篇搞定

前言 说到测试用例,但凡是软件测试从业人员,都不会陌生。但对于测试新手来说,测试用例仍旧有遗漏,或者写不好的时候。那么,究竟应该如何写好测试用例呢?今天就来针对性的聊聊这个话题。 在分析如何写测试…

event.stopPropagation()

现在有如下 当点击子按钮的时候会触发子事件,同时也会触发父事件, 如何阻止呢 handleDownload(event) { event.stopPropagation(); 。。。。。。。。。。 },

算法 分糖果-(贪心)

牛客网: BM95 题目: 每个孩子至少一个糖果,相邻孩子中得分高的至少多一些,最少多少糖果。 思路: 初始化candy数组元素全为1,从1往右遍历,arr[i]>arr[i-1], 需要candy[i]candy[i-1]1;total candy[n-1], 从右往左遍…

【每日一题】658. 找到 K 个最接近的元素

658. 找到 K 个最接近的元素 - 力扣(LeetCode) 给定一个 排序好 的数组 arr ,两个整数 k 和 x ,从数组中找到最靠近 x(两数之差最小)的 k 个数。返回的结果必须要是按升序排好的。 整数 a 比整数 b 更接近 …