【数据结构实践】手把手带你实现 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]
目录
相关文章
|
25天前
|
机器学习/深度学习 算法 数据挖掘
线性回归模型的原理、实现及应用,特别是在 Python 中的实践
本文深入探讨了线性回归模型的原理、实现及应用,特别是在 Python 中的实践。线性回归假设因变量与自变量间存在线性关系,通过建立线性方程预测未知数据。文章介绍了模型的基本原理、实现步骤、Python 常用库(如 Scikit-learn 和 Statsmodels)、参数解释、优缺点及扩展应用,强调了其在数据分析中的重要性和局限性。
53 3
|
9天前
|
数据可视化 算法 数据挖掘
Python量化投资实践:基于蒙特卡洛模拟的投资组合风险建模与分析
蒙特卡洛模拟是一种利用重复随机抽样解决确定性问题的计算方法,广泛应用于金融领域的不确定性建模和风险评估。本文介绍如何使用Python和EODHD API获取历史交易数据,通过模拟生成未来价格路径,分析投资风险与收益,包括VaR和CVaR计算,以辅助投资者制定合理决策。
53 15
|
16天前
|
测试技术 开发者 Python
探索Python中的装饰器:从入门到实践
装饰器,在Python中是一块强大的语法糖,它允许我们在不修改原函数代码的情况下增加额外的功能。本文将通过简单易懂的语言和实例,带你一步步了解装饰器的基本概念、使用方法以及如何自定义装饰器。我们还将探讨装饰器在实战中的应用,让你能够在实际编程中灵活运用这一技术。
36 7
|
15天前
|
存储 缓存 Python
Python中的装饰器深度解析与实践
在Python的世界里,装饰器如同一位神秘的魔法师,它拥有改变函数行为的能力。本文将揭开装饰器的神秘面纱,通过直观的代码示例,引导你理解其工作原理,并掌握如何在实际项目中灵活运用这一强大的工具。从基础到进阶,我们将一起探索装饰器的魅力所在。
|
18天前
|
开发者 Python
Python中的装饰器:从入门到实践
本文将深入探讨Python的装饰器,这一强大工具允许开发者在不修改现有函数代码的情况下增加额外的功能。我们将通过实例学习如何创建和应用装饰器,并探索它们背后的原理和高级用法。
34 5
|
23天前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
44 5
|
29天前
|
机器学习/深度学习 人工智能 数据可视化
使用Python进行数据可视化:探索与实践
在数字时代的浪潮中,数据可视化成为了沟通复杂信息和洞察数据背后故事的重要工具。本文将引导读者通过Python这一强大的编程语言,利用其丰富的库函数,轻松入门并掌握数据可视化的基础技能。我们将从简单的图表创建开始,逐步深入到交互式图表的制作,最终实现复杂数据的动态呈现。无论你是数据分析新手,还是希望提升报告吸引力的专业人士,这篇文章都将是你的理想指南。
39 9
|
24天前
|
数据采集 XML 存储
构建高效的Python网络爬虫:从入门到实践
本文旨在通过深入浅出的方式,引导读者从零开始构建一个高效的Python网络爬虫。我们将探索爬虫的基本原理、核心组件以及如何利用Python的强大库进行数据抓取和处理。文章不仅提供理论指导,还结合实战案例,让读者能够快速掌握爬虫技术,并应用于实际项目中。无论你是编程新手还是有一定基础的开发者,都能在这篇文章中找到有价值的内容。
|
24天前
|
设计模式 缓存 开发者
Python中的装饰器:从入门到实践####
本文深入探讨了Python中强大的元编程工具——装饰器,它能够以简洁优雅的方式扩展函数或方法的功能。通过具体实例和逐步解析,文章不仅介绍了装饰器的基本原理、常见用法及高级应用,还揭示了其背后的设计理念与实现机制,旨在帮助读者从理论到实战全面掌握这一技术,提升代码的可读性、可维护性和复用性。 ####
|
27天前
|
存储 开发者 Python
Python 编程基础:从入门到实践
本文旨在通过深入浅出的方式,向初学者介绍 Python 编程语言的基础概念和实践应用。我们将从 Python 的基本语法开始,逐步过渡到函数、模块的使用,最后以实际项目案例结束,帮助读者构建起完整的编程知识体系。
39 3
下一篇
DataWorks