「Python系列」 Python 数据结构之数组
off999 2024-10-01 13:47 34 浏览 0 评论
在大多数编程语言中,数组都是一个基础而又普遍的数据结构。在很多算法中都有广泛的应用。
在本文中,我们将了解鲜为人知的Python数组实现,该实现仅使用Python标准库中包含的核心语言功能。
我们将看到每种方法的优点和缺点,以便我们可以决定哪种实现最适合我们的用例。但是在开始之前,让我们先介绍一些基础知识。
数组如何工作,它们的作用是什么?
数组由固定大小的数据记录组成,这些数据记录允许每个元素根据其索引进行有效定位。
在性能方面,给定元素的索引,查找数组中包含的元素非常快。在这种情况下,适当的数组实现可确保O(1)的访问时间恒定。
Python在标准库中包含具有不同特征的多个类似数组的数据结构。让我们看看它们。
array.array —基本类型数组
Python的数组模块可以节省空间地存储基本的C样式数据类型,例如字节,32位整数,浮点数等。
使用array.array类创建的数组是可变的,并且行为类似于列表,除了一个重要的区别—它们是“类型化数组”,被约束为单个数据类型。
由于此约束,具有许多元素的array.array对象比列表和元组更节省空间。存储在它们中的元素是紧密包装的,如果我们需要存储许多相同类型的元素,这将很有用。
此外,数组支持许多与常规列表相同的方法,并且我们可以将它们用作“直接替换”,而无需对应用程序代码进行其他更改。
>>> import array
>>> arr = array.array('i', (22, 30, 10, 6))
>>> arr[1]
30
# Arrays are mutable
arr[1] = 25
>>> arr
array('i', [22, 25, 10, 6])
>>> arr.append(27)
>>> arr
array('i', [22, 25, 10, 6, 27])
# Arrays are typed
>>> arr[1] = "Sarah"
TypeError: an integer is required (got type str)str — Unicode字符的不可变数组
str是一个不变的字符数组,用于将文本数据存储为Unicode字符。而且,它是一个递归数据结构-字符串中的每个字符本身都是长度为1 的str对象。
字符串对象节省空间,因为它们被紧密包装并且专门用于单一数据类型。由于字符串在Python中是不可变的,因此修改字符串需要创建修改后的副本。
>>> arr = 'Sarah'
>>> arr[1]
'a'
>>> arr
'Sarah'
# String are immutable
>>> arr[1] = 'k'
TypeError: 'str' object does not support item assignment
# Strings are recursive data structures
>>> type('Sarah')
<class 'str'>
>>> type('Sarah'[1])
<class 'str'>bytes —不可变的单字节数组
字节对象是单个字节的不可变序列(整数范围为0≤x≤255)。从概念上讲,它们类似于str对象。
像字符串一样,字节有其自己的用于创建对象的文字语法,而且它们节省空间。
>>> arr = bytes((22, 30, 10, 6))
>>> arr[1]
30
# Bytes literals have their own syntax
>>> arr
b'\x16\x1e\n\x06'
# Bytes are immutable
>>> arr[1] = 25
TypeError: 'bytes' object does not support item assignment
>>> del arr[1]
TypeError: 'bytes' object doesn't support item deletion
# Only valid bytes are allowed:
>>> bytes((0, 2206))
ValueError: bytes must be in range(0, 256)bytearray —单字节可变数组
该字节组类型是整数的范围内的可变序列0≤X≤255他们是密切相关的字节与主要区别在于对象的ByteArray可以随意修改-我们可以覆盖的元素,删除或添加新的。该字节组对象将增长,并相应地缩小。
字节数组可以转换回不可变的字节对象,但这涉及到完整复制存储的数据-耗时O(n)的缓慢操作。
>>> arr = bytearray((22, 30, 10, 6))
>>> arr[1]
30
# The bytearray repr:
>>> arr
bytearray(b'\x16\x1e\n\x06')
# bytearrays are mutable
>>> arr[1] = 25
>>> arr[1]
25
>>> arr
bytearray(b'\x16\x19\n\x06')
>>> del arr[1]
>>> arr
bytearray(b'\x16\n\x06')
>>> arr.append(27)
>>> arr
bytearray(b'\x16\n\x06\x1b')
# bytearrays can hold valid bytes
>>> arr[1] = 2206
ValueError: byte must be in range(0, 256)
>>> arr[1] = "Sarah"
TypeError: 'str' object cannot be interpreted as an integer
# bytearrays can be converted back into
# bytes objects
>>> bytes(arr)
b'\x16\n\x06\x1b'结论:
- 如果我们要存储具有混合数据类型的任意对象,则可以使用列表或元组对象。
- 当我们拥有数值数据和紧密包装以及性能很重要时,我们可以尝试使用array.array。
- 我们可以使用内置的str对象将文本数据表示为Unicode字符。
- 当我们要存储连续的字节块时,不可变的字节类型或字节数组可以派上用场。
相关推荐
- 笔记本电脑系统修复软件(笔记本电脑程序修复)
-
1、超级兔子2013系统修复软件超级兔子是一款完整的系统维护工具。拥有电脑系统评测、垃圾清理和注册表清理、可疑文件和插件检测、网页防护等功能,同时自带一些实用的系统工具,可清理你大多数的文件、注册表里...
- 联想保修服务包括哪些(联想保修都保修什么)
-
1、保修36个月的硬件包括:CPU、内存。2、保修24个月的硬件包括:主板、显卡、LCD屏、硬盘、电源适配器、键盘、鼠标模块。3、保修12个月的硬件包括:LCD之附件、光驱、DVD、CDR/W、软驱...
- 系统科学大会(中国系统科学学会)
-
2021年各种科学大会的召开时间取决于疫情的发展和国家政策的调整。一些大型的国际科学会议可能会推迟或者采用线上形式进行,以保障参会人员的安全和健康。同时,一些国内的学术会议也会受到疫情的影响,需要推迟...
- win10系统下载的内容在哪(win10下载的软件在哪个文件夹)
-
进入C:\Windows\SoftwareDistribution\Download目录下,通过win10应用商店中下载的安装包都放在此目录下。进入C:\Windows\SoftwareDistrib...
- 下载原版xp系统光盘(xp光盘系统安装教程怎么安装)
-
方法步骤步骤如下:1、首先打开计算机,在电脑光驱上放入XP光盘,启动电脑后不停按F12、F11、Esc等启动热键,在弹出的启动菜单中选择DVD选项,回车。2、进入光盘主菜单,按数字2或点击选项2运行w...
- windows7中文版下载安装(windows7安装包下载)
-
谢邀,如果你戳设置-时间和语言-区域和语言,右边的语言提示“只允许使用一种语言包”,那么你的系统就是家庭中文版。家庭中文版限定系统界面只能使用简体中文显示,其他功能则与普通家庭版没有区别,也可以使用其...
- win7开机按f2怎么重装系统(win7开机按f12怎么重装系统)
-
开机或重启时,在进入Windows前按F2进入BIOS。 ←→移动到第三个好像是BOOT。 然后将EXTENELBOOT选项设置为ENABLE 最后按F5将第一启动项目设置为EXTENEL...
-
- win10驱动管理(win10驱动程序)
-
win10由于联网后会自动安装驱动,如果自动安装驱动没出现问题,即可视为最佳驱动,若出现问题,卸载出问题的驱动,然后去查自己主板型号,在主板供应商官网下载对应驱动即是最佳01Windows10驱动更新调整当前当你插入连接即插即用(Pn...
-
2025-12-29 05:51 off999
- 手机上怎么找qq邮箱登录(用手机怎么找到qq邮箱)
-
入口是“联系人”选项卡。qq邮箱手机在QQ主菜单中选择下方的“联系人”选项卡;3、在“联系人”中选取“公众号”选项卡;4、在公众号中菜单中找到或搜索“QQ邮箱提醒”,点击进入;5、点击“进入邮箱”;6...
- amd显卡控制面板
-
AMD显卡控制面板是用来管理你的AMD显卡的,可以在控制面板中进行设置一些简单的调整,来提升显卡性能和效果。1、先打开AMD控制面板。2、打开“垂直同步(V-SYNC)”功能,可调整细节,改善影像流畅...
- win10老是未响应卡死(window10总是未响应)
-
具体方法:1、如果win10中的应用程序出现不响应的情况,应该是应用程序加载失败了。可以通过重置方法来解决win10应用程序无响应。2、登录win10系统,用管理员身份运行Powershell(可在C...
- usb安装系统步骤(USB安装系统步骤)
-
1.准备一张U盘,将联想官网下载的系统镜像文件复制到U盘中;2.将U盘插入联想S41U电脑,重启电脑,按F12进入BIOS设置,将U盘设置为启动项;3.重启电脑,进入U盘安装界面,按提示操作,完成系统...
- win98安装教程(win98iso怎么安装)
-
如何安装windows98 一、具体安装步骤 备份好重要文件之后,就可以安装windows98了。 第一步:启动安装程序。 用户如果原来已安装了windows95/97/98,现在拟对其进行升...
- 雨林木风win7安装(雨林木风win732位安装教程)
-
安装步骤如下: 1、光盘放入光驱,复制光盘上的win7.gho和安装系统.exe到硬盘非C盘的文件夹;(gho文件名可以是其他名字,后缀为gho,体积最大的就是。) 2、双击安装系统.exe;...
- win10解绑管理员账户(win10管理员账户怎么取消开机密码)
-
要解除Windows10电脑上的管理员权限,您需要进行以下操作:1.打开“控制面板”:右键单击“开始”按钮,然后选择“控制面板”。2.进入“用户账户”:在控制面板中,选择“用户账户”。3.点击...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
