python顺序表代码_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.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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值