python简单代码-python实现顺序表的简单代码

顺序表即线性表的顺序存储结构。它是通过一组地址连续的存储单元对线性表中的数据进行存储的,相邻的两个元素在物理位置上也是相邻的。比如,第1个元素是存储在线性表的起始位置LOC(1),那么第i个元素即是存储在LOC(1)+(i-1)*sizeof(ElemType)位置上,其中sizeof(ElemType)表示每一个元素所占的空间。

2018928101332861.jpg?2018828101344

下面是顺序表的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

#输出操作

def printList(self):

for i in range(0,self.num):

print self.date[i]

#销毁操作

def destroy(self):

self.__init__()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值