搜索
您的当前位置:首页正文

python实现顺序表的简单代码

来源:意榕旅游网
python实现顺序表的简单代码

顺序表即线性表的顺序存储结构。它是通过⼀组地址连续的存储单元对线性表中的数据进⾏存储的,相邻的两个元素在物理位置上也是相邻的。⽐如,第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 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__()

以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。

因篇幅问题不能全部显示,请点此查看更多更全内容

Top