【数据结构实践】手把手带你实现 Python 自定义数组

简介: 无论是任何语言,数组或者类似数组的数据结构永远是计算机编程语言不可或缺的基本数据结构,有了数组的存在更有利于我们的程序对数据的存储和操作.本文将从面向对象的入手,实现自定义数组类,实现数组的基本操作和运算等功能1、数组(Array)是有序的元素序列。若将有限个类型相同的变量的集合命名,那么这个名称为数组名。2、组成数组的各个变量称为数组的分量,也称为数组的元素,有时也称为下标变量。3、用于区分数组的各个元素的数字编号称为下标。数组是在程序设计中,为了处理方便, 把具有相同类型的若干元素按有序的形式组织起来的一种形式。这些有序排列的同类数据元素的集合称为数组。也就是说数组是存储相同类型数据

引言


无论是任何语言,数组或者类似数组的数据结构永远是计算机编程语言不可或缺的基本数据结构,有了数组的存在更有利于我们的程序对数据的存储和操作.本文将从面向对象的入手,实现自定义数组类,实现数组的基本操作和运算等功能


数组的定义


1、数组(Array)是有序的元素序列。若将有限个类型相同的变量的集合命名,那么这个名称为数组名。

2、组成数组的各个变量称为数组的分量,也称为数组的元素,有时也称为下标变量。

3、用于区分数组的各个元素的数字编号称为下标。数组是在程序设计中,为了处理方便, 把具有相同类型的若干元素按有序的形式组织起来的一种形式。这些有序排列的同类数据元素的集合称为数组。也就是说数组是存储相同类型数据的集合


什么是面向对象


面向对象是一种软件开发方法,面向对象的概念和应用已经超越了程序设计和软件开发。面向对象中的对象,通常是指客观世界中存在的对象,这个对象具有唯一性,对象之间各不相同,各有各的特点,每一一个对象都有运动的规律和内部状态。对象与对象之间是可以相互联系、相互作用的。另外,对象也可以是一个抽象的事物。

1、对象( Object): -一个抽象概念,表示任意存在的事物。现实世界中,随处可见的一一种事物就是对象,对象是事物存在的实体。对象通常被划分为两个部分,即静态部分与动态部分。 静态部分通常被称为这个对象的属性,任何对象都具有自身属性,这些属性不仅是客观存在的。而且是不能被忽略的,如人的姓名,年龄等等。动态部分指的是对象的行为,即对象执行的动作,如人可以跑步。

2、类(Class):封装对象的属性和行为的获体。反过来说,具有相同属性和行为的一类实体被称为类。


Python中类的定义如下:

classClassName:#类名使用大驼峰法,即首字母大写#类的语句块如类的成员属性...
类的方法...

当我们创建完类之后,接着就是类的使用,使用前需要对类进行实例化


比如有个Dog类

classDog:
def__init__(self, name):
self.name=name# 类的实例化如下d1=Dog("小北")


面向对象程序设计的特点:封装、继承和多态


封装:面向对象编程的核心,也是将对象的属性和行为封装起来的载体。类通常会对客尸隐臧其实现细节,这就是封装的思想。封装通过限制只有特定类的对象,访问这一 特定类的成员,而它们通常利用接口实现消息的传人和传出。采用封装思想保证了类的内部数据结构的完整性,使用该类的用户不能直接看到类中的数据结构,而只能执行类允许公开的数据,这样就可以避免外部对内部数据的影响,提高了程序的可维护性。

继承:在某种情况下,一个类会有子类,子类比原本的类要更加具体化。例如,犬这个类会有它的子类--拉布拉多犬,猎犬和泰迪犬等。“小北”可能就是哈士奇犬的一个实例。 子类会继承父类的属性和行为,并且也包含它们自己的特有属性。我们假设犬类有一个行为叫作吠叫,还有一一个属性叫作毛色,它的子类会继承这些行为和属性。综上所述,继承是实现重复利用的重要手段, 子类通过继承, 复用了父类的实现和行为,同时又添加了子类特有的属性和行为。


多态:由继承产生的不同的类,其对象对同一消息会做出不同的响应。子类继承父类特征的同时,也具备了自己的特征,并且能够实现不同的效果,这就是多态化结果。

这里只是简单唠唠面向对象的基本概念。我之前写过的一篇文章《梦回战国,领略两千多年前公孙龙如何将面向对象运用得炉火纯青》有关于面向对象的详细介绍,感兴趣的同学可参考参考。


自定义数组的实现步骤


网络异常,图片无法展示
|


使用python实现自定义数组,以及实现数组中的各种运算:

  1. 保证输入值为数字元素,通过isinstance()函数判断数据类型
  2. 初始化__init__函数,对输入的数据进行存储
  3. 重构数组的运算方法
  4. 添加数组类的类方法


代码实现


创建MyNArrays类,以及定义元素类过滤方法

classMyNArrays:
#过滤非数字类型的元素def___isNumber(self, n):
ifnotisinstance(n,(int,float,complex)):
returnFalsereturnTrue#类属性等初始化def__init__(self,*args):
ifnotargs:
self.__value= []
else:
forarginargs:
ifnotself.___isNumber(arg):
print('All elements must be numbers')
returnself.__value=list(args)
@propertydefgetValue(self):
returnself.__value#析构函数,释放内部封装的列表def__del__(self):
delself.__value#重载运算符+def__add__(self, other):
#数组中每个元素都与数字other相加,或者两个数组相加,会得到一个新数组ifself.___isNumber(other):
#数组与数字other相加b=MyNArrays()
b.__value= [item+otherforiteminself.__value]
returnbelifisinstance(other,MyNArrays):
#两个数组对应元素相加if (len(other.__value) ==len(self.__value)):
c=MyNArrays()
c.__value= [i+jfori,jinzip(self.__value,other.__value)]
returncelse:
print('Lenght no equal')
else:
print('Not supported')
#重载运算符-def__sub__(self, other):
# 数组元素与数字other做减法,得到一个新数组pass#重载运算符*def__mul__(self, other):
#数组元素与数字other做乘法,或者两个数组相乘,得到一个新数组passdef__truediv__(self, other):
passdef__floordiv__(self, other):
passdef__pow__(self, power, modulo=None):
passdef__mod__(self, other):
pass#重载数组len,支持对象直接使用len()方法def__len__(self):
returnlen(self.__value)
#支持使用print()函数查看对象的值def__str__(self):
returnstr(self.__value)
def__contains__(self, n):
ifninself.__value:
returnTruereturnFalsedefdot(self,v):
ifnotisinstance(v,MyNArrays):
print('must be an instance of MyNArrays.')
returniflen(v)!=len(self.__value):
print('size must be equal.')
returnreturnsum([i*jfori,jinzip(self.__value,v.__value)])
#让本类具有修改数组元素的功能def__setitem__(self, key, value):
length=len(self.__value)
ifisinstance(key,int) and0<=key<length:
self.__value[key]=valueelse:
return'index error'#获取数组元素   def__getitem__(self, key):
length=len(self.__value)
ifisinstance(key, int) and0<=key<length:
returnself.__value[key]
else:
return'index error'#向数组中添加元素   defappend(self,n):
ifisinstance(n,(int,float)):
self.__value.append(n)
else:
print('isinstance error')
def__repr__(self):
returnrepr(self.__value)


注:重载运算中用到zip()函数用于将可迭代对象作为参数,将对象中对应的元素打包成元组,然后返回由这些元组组成的列表


完成了自定义数组类的定义.接下来就是对类的调用.是骡子是马拉出来溜溜


创建数组:

a=MyNArrays(1,2,3,4,5,6)
b=MyNArrays(7,8,9,10,11,12)
print('数组a:',a)
print('数组b:',b)


执行结果:

数组a: [1, 2, 3, 4, 5, 6]
数组b: [7, 8, 9, 10, 11, 12]


数组的运算:

print('a+b:',a+b)
print('a和b的内积为:', a.dot(b))

执行结果:

a+b: [8, 10, 12, 14, 16, 18]
a和b的内积为: 217


数组的增删改查操作

print('2是否为a的元素:',2ina)
a.append(17)
print('a添加元素17:',a)
print('查看a的第3各元素值:',a[2])
a[6]=15print('修改最后一项值为15:',a)


执行结果:

2是否为a的元素: True
a添加元素17: [1, 2, 3, 4, 5, 6, 17]
查看a的第3各元素值: 3
修改最后一项值为15: [1, 2, 3, 4, 5, 6, 15]
目录
相关文章
|
12天前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
39 2
|
4天前
|
前端开发 Python
使用Python+openpyxl实现导出自定义样式的Excel文件
本文介绍了如何使用Python的openpyxl库导出具有自定义样式的Excel文件,包括设置字体、对齐方式、行列宽高、边框和填充等样式,并提供了完整的示例代码和运行效果截图。
8 1
使用Python+openpyxl实现导出自定义样式的Excel文件
|
1天前
|
数据采集 存储 中间件
Python进行网络爬虫:Scrapy框架的实践
【8月更文挑战第17天】网络爬虫是自动化程序,用于从互联网收集信息。Python凭借其丰富的库和框架成为构建爬虫的首选语言。Scrapy作为一款流行的开源框架,简化了爬虫开发过程。本文介绍如何使用Python和Scrapy构建简单爬虫:首先安装Scrapy,接着创建新项目并定义爬虫,指定起始URL和解析逻辑。运行爬虫可将数据保存为JSON文件或存储到数据库。此外,Scrapy支持高级功能如中间件定制、分布式爬取、动态页面渲染等。在实践中需遵循最佳规范,如尊重robots.txt协议、合理设置爬取速度等。通过本文,读者将掌握Scrapy基础并了解如何高效地进行网络数据采集。
20 6
|
7天前
|
开发者 Python
Python中的异常处理机制及其实践
【8月更文挑战第12天】Python的异常处理机制通过`try`和`except`结构显著提高了程序的稳定性和可靠性。在`try`块中执行可能引发异常的代码,如果发生异常,控制权将转移到与该异常类型匹配的`except`块。此外,还可以通过`else`处理无异常的情况,以及使用`finally`确保某些代码无论如何都会被执行,非常适合进行清理工作。这种机制允许开发者精确地捕捉和管理异常,从而提升程序的健壮性和可维护性。同时,Python还支持定义自定义异常,进一步增强了错误处理的灵活性。
23 4
|
12天前
|
数据采集 JSON 数据可视化
基于Python的51job招聘数据采集与可视化项目实践
本文介绍了一个基于Python的51job招聘数据采集与可视化项目,该项目通过自动化手段获取大量招聘信息,并运用数据分析和可视化工具对就业市场进行深度分析,旨在为求职者和企业提供数据支持和决策依据。
|
13天前
|
Python
【Leetcode刷题Python】剑指 Offer 21. 调整数组顺序使奇数位于偶数前面
Leetcode题目"剑指 Offer 21. 调整数组顺序使奇数位于偶数前面"的两种Python解决方案,一种是使用双端队列调整数组顺序,另一种是使用双指针法将奇数移到数组前半部分,偶数移到后半部分。
15 4
|
13天前
|
Python
Python函数式编程:你真的懂了吗?理解核心概念,实践高阶技巧,这篇文章带你一次搞定!
【8月更文挑战第6天】本文介绍了Python中的函数式编程,探讨了高阶函数、纯函数、匿名函数、不可变数据结构及递归等核心概念。通过具体示例展示了如何利用`map()`和`filter()`等内置函数处理数据,解释了纯函数的一致性和可预测性特点,并演示了使用`lambda`创建简短函数的方法。此外,文章还强调了使用不可变数据结构的重要性,并通过递归函数实例说明了递归的基本原理。掌握这些技巧有助于编写更清晰、模块化的代码。
14 3
|
13天前
|
Python
【Leetcode刷题Python】剑指 Offer 11. 旋转数组的最小数字
解决剑指Offer 11题 "旋转数组的最小数字" 的三种Python实现方法:直接使用min函数、线性查找分界点和二分查找法,以找出旋转数组中的最小元素。
23 2
|
5天前
|
机器学习/深度学习 安全 网络安全
探索数字取证的核心技术与实践,通过Python编程语言的应用实例
在网络的无垠海洋中,数字取证如同一位高明的侦探,穿梭于数据的密林,追踪着网络犯罪的蛛丝马迹。它不仅是法律正义的守护者,更是信息安全领域的一把利剑,用科学的方法揭示真相,保护网络空间的和平与秩序。本文旨在探索数字取证的核心技术与实践,通过Python编程语言的应用实例,展示如何在海量数据中寻找线索,分析网络攻击行为,为网络安全防御提供强有力的支持。
12 0
|
7天前
|
前端开发 Python
数据结构Python用队列实现杨辉三角形
数据结构Python用队列实现杨辉三角形
11 0