[数据结构学习笔记3] 数组

news/2025/1/5 7:26:08/文章来源:https://www.cnblogs.com/Eagle6970/p/18649758

数组是用于存放一组数据,把这组数据存放在连续的空间里。通常有插入,删除,查找,访问等操作。

举例:

购物清单,初始状态:

清单:牛奶 -> 鸡蛋 -> 奶油 -> 火腿 -> 果汁

下标:0           1          2           3          4

插入:

1. 插在末尾

清单:牛奶 -> 鸡蛋 -> 奶油 -> 火腿 -> 果汁 -> 西红柿

下标:0           1          2           3          4          5

2. 插在中间

清单:牛奶 -> 鸡蛋 -> 奶油  -> 糖果 -> 火腿 -> 果汁 -> 西红柿

下标:0           1          2             3          4          5           6

删除:

1. 删除末尾

清单:牛奶 -> 鸡蛋 -> 奶油  -> 糖果 -> 火腿 -> 果汁

下标:0           1          2             3          4          5

2. 删除头部

清单:鸡蛋 -> 奶油  -> 糖果 -> 火腿 -> 果汁

下标:0           1          2             3          4

搜索:

一般需要遍历数字来做搜索,对于特殊的情况,可以优化,比如折半查找。

访问数组元素:

使用下标,直接访问。

 

代码实现,这里用的是Javascript。

 

// Create our array!
let groceries = ["Milk", "Eggs", "Cereal", "Salami", "Juice"];// Access the first item
let first = groceries[0];// Access the last item
let last = groceries[groceries.length - 1];// Access the 3rd item
let cereal = groceries[2];// Insert item at the end
groceries.push("Potatoes");// Insert item at the beginning
groceries.unshift("Ice Cream");// Insert item after the 3rd item
groceries.splice(3, 0, "Cheese");// Remove last item
groceries.pop();// Remove first item
groceries.shift();// Delete the 3rd item
groceries.splice(2, 1);// Find a particular item
let foundIndex = groceries.indexOf("Eggs"); // 1// Iterate through each item
let itemToFind = -1;
for (let i = 0; i < groceries.length; i++) {let currentItem = groceries[i];if (currentItem == "Salami") {itemToFind = i;          }    
}

 

数组和内存

数组会被分配在连续的内存中,初始化时,分配好内存。随着放入的元素越来越多,可能会达到初始分配最大值,这个时候系统会找到内存中另一块符合条件的连续空间,然后重新分配,并且把当前的数据copy到新分配的空间。所以,一旦有空间不够,需要重新分配的情况,开销可能会大。

 

时间复杂度

动作 平均复杂度 最坏复杂度
空间分配 O(n) O(n)
随机访问 O(1) O(1)
末尾插入 O(1) O(n) - 需要重新分配空间
非末尾插入 O(n) O(n)
删除 O(1) O(n)
末尾删除 O(1) O(1)
线性搜索 O(n) O(n)
二叉查找 O(log n) O(n) - 非排序数组

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

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

相关文章

断点输出大法快速定位编程错误

断点&输出大法快速定位编程错误 1、断点法 点红框位置就可以加每行代码的断点 再按F5进行debug断点&输出大法快速定位编程错误 1、断点法 点红框位置就可以加每行代码的断点再按F5进行debug操作,在下面的窗口看各函数的值 这种方法经常用在循环出现问题时进行处理 举个…

Nginx的referer参数的用法和原理

​ Nginx的referer参数是用于控制HTTP请求中的Referer字段的相关配置。这个参数的主要作用是限制或允许特定来源网站的访问,以加强安全性或控制流量。 用法:限制特定来源网站的访问: 可以使用referer参数来配置Nginx,使其只允许来自指定来源网站的请求。这有助于防止盗链或…

.Net程序员机会来了,微软官方新推出一个面向Windows开发者本地运行AI模型的开源工具

想要开发AI产品的.Net程序员机会来了,这个项目应该好好研究。 虽然说大模型基本都有提供网络API,但肯定没有直接使用本地模型速度快。 最近微软官方新推出AI Dev Gallery开源项目,可以帮助Windows开发人员学习如何将具有本地模型和API的AI添加到Windows应用程序中。01 项目简…

ABB工业机器人SIB-V板维修细节分享

要判断ABB机器人SIB-v板是否需要更换,可以从以下几个方面进行评估: - 检查SIB-v板的状态:查看SIB-v板是否有明显的物理损坏,如烧焦、裂纹或其他损坏迹象。 - 检查连接情况:确保SIB-v板与其他组件的连接牢固,没有松动或腐蚀。 - 检查电池状态:如果SIB-v板上有…

KUKA机械臂驱动器600-20 1X64 UL故障维修细节

库卡机器人作为工业自动化的重要设备,其稳定性和可靠性对于生产线的正常运转至关重要。然而,在使用过程中,KUKA机械臂驱动器故障是不可避免的问题之一。 一、常见KUKA机械手驱动器故障及原因分析 1. 过热故障 过热是常见的库卡工业机器人驱动器600-20 1X64 UL故障之一。这通…

PostgreSQL技术大讲堂 - 第77讲:DB4AI 搭建PG向量数据库AI机器人

PostgreSQL技术大讲堂 - 第77讲,主题:DB4AI 搭建PG向量数据库AI机器人 讲课内容: 1、 向量搜索引擎(PGVector)介绍 2、 向量与Embeddings的定义 3、 向量间的相似度计算方法演示 4、检索增强生成模型(RAG)介绍 5、PG向量数据库+通义千问大模型实现AI机器人 目前主流的关系型…

ABAP excel上传时,数字带文本逗号 转ABAP数量QUAN金额CURR 格式

主要使用 函数MOVE_CHAR_TO_NUM 或者 UNITS_STRING_CONVERT 第二个需要限制客户SU3 参数配置X 或者函数入参默认X, excel导出默认时X格式, 样例参考代码*&---------------------------------------------------------------------* *& Report YWWZ_TEST57 *&…

11 个必备 Docker 工具

​ 1. LazyDocker命令行下的 Docker 管理利器LazyDocker 是一个为命令行用户设计的友好型终端工具,用于管理 Docker 容器、镜像和存储卷。它适合那些习惯于命令行操作但又希望拥有直观界面的用户。 通过 LazyDocker,你可以一站式查看容器的状态、资源消耗、日志等详细信息,并…

大语言模型提示技巧(三)-迭代式提示

大语言模型还没有达到能够准确猜测人类意图的程度,此时它不能立即反馈出令人满意的答复,我们需要做的是对大语言模型进行迭代式提示,反复推进,直至大语言模型给出了令人满意的答案。我们与大语言模型交互时,往往给出的提示过于简略,而大语言模型还没有达到能够准确猜测你…

spring 中 Bean 的生命周期

spring 中 Bean 的生命周期是怎样的?原文 连环18问 https://mp.weixin.qq.com/s/liWn2Dn91cmuiqHSxVO_fASpringBean 生命周期大致分为4个阶段:1.「实例化」,实例化该 Bean 对象2.「填充属性」,给该 Bean 赋值3.「初始化」如果实现了 Aware 接口,会通过其接口获取容器资源如…

一步一步构建RAG智能问答系统

一步一步基于LangChain构建智能问答系统(Construct intelligent question answering system based on LangChain)虽然LLM(大语言模型)非常强大,但它们对于它们未经训练的信息一无所知。如果想使用LLM来回答它未经训练的文档相关问题,我们需要向其提供这些文档的信息。最常…