数据结构--顺序表定义及python实现
来源:互联网 发布:网络电信诈骗 编辑:程序博客网 时间:2024/06/04 17:47
顺序表即线性表的顺序存储结构。它是通过一组地址连续的存储单元对线性表中的数据进行存储的,相邻的两个元素在物理位置上也是相邻的。比如,第1个元素是存储在线性表的起始位置LOC(1),那么第i个元素即是存储在LOC(1)+(i-1)*sizeof(ElemType)位置上,其中sizeof(ElemType)表示每一个元素所占的空间。
下面是顺序表的python实现:
#coding:utf-8'''author:xzfreewind'''class SeqList(object): def __init__(self,max=10): self.max = max #默认顺序表最多容纳10个元素 #初始化顺序表数组 self.num = 0 self.date = [None] * self.max def is_empty(self): #判定线性表是否为空 return self.num is 0 def is_full(self): #判定线性表是否全满 return self.num is self.max #获取线性表种某一位置的元素 def __getitem__(self, i): if not isinstance(i,int): #如果i不为int型,则判定输入有误,即Type错误 raise TypeError if 0<= i < self.num: #如果位置i满足条件,即在元素个数的范围内,则返回相对应的元素值,否则,超出索引,返回IndexError return self.date[i] else: raise IndexError #修改线性表种某一位置的元素 def __setitem__(self, key, value): if not isinstance(key,int): #如果key不为int型,则判定输入有误,即Type错误 raise TypeError if 0<= key <self.num: #如果位置key满足条件,即在元素个数的范围内,则返回相对应的元素值,否则,超出索引,返回IndexError self.date[key] = value else: raise IndexError #按值查找元素的位置 def getLoc(self,value): n = 0 for j in range(self.num): if self.date[j] == value: return j if j == self.num: return -1 #如果遍历顺序表还未找到value值相同的元素,则返回-1表示顺序表种没有value值的元素 #统计线性表中元素的个数 def Count(self): return self.num #表末尾插入操作 def appendLast(self,value): if self.num >= self.max: print 'The list is full' return else: self.date[self.num] = value self.num += 1 #表任意位置插入操作: def insert(self,i,value): if not isinstance(i,int): raise TypeError if i < 0 and i > self.num: raise IndexError for j in range(self.num,i,-1): self.date[j] = self.date[j-1] self.date[i] = value self.num += 1 #删除某一位置的操作 def remove(self,i): if not isinstance(i,int): raise TypeError if i < 0 and i >=self.num: raise IndexError for j in range(i,self.num): self.date[j] = self.date[j+1] self.num -= 1 #输出操作 def printList(self): for i in range(0,self.num): print self.date[i] #销毁操作 def destroy(self): self.__init__()
阅读全文
0 0
- 数据结构--顺序表定义及python实现
- 数据结构顺序表定义和实现
- 数据结构之栈的定义及python实现
- 数据结构学习之线性表的顺序实现(python 实现)
- 数据结构顺序表实现
- 基础数据结构:顺序表、链表——Python实现
- 数据结构 - 2顺序表及链表基本运算实现
- 数据结构(一)——顺序表及实现
- 数据结构顺序表的定义(Java)
- 数据结构 顺序表及合并
- 数据结构--顺序存储结构及抽象实现
- 数据结构之串15定义及实现
- 数据结构之数组16定义及实现
- 数据结构线性表顺序结构的定义与实现C语言
- 数据结构---顺序表实现(源码)
- 数据结构实现顺序线性表
- 数据结构顺序表的实现
- 数据结构---顺序表c实现
- 共享内存linux C/C++代码实战------顺便玩下ipcs, ipcrm, shmget, shmat, shmdt, shmctl
- 目录 《虚拟机就是开发板》
- 题目1380:lucky number
- java设计模式---原型模式篇
- Android 资源引用
- 数据结构--顺序表定义及python实现
- Android使用Properties保存本地配置
- Qt之TCP、UDP传输模型
- intanceof的用法
- Mac环境运行mvn报错
- Android selector
- Nginx+Tomcat集群故障迁移实现
- Python中用format函数格式化
- Bootstrap Multiselect插件使用步骤以及常见参数配置介绍