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

本文介绍了顺序表的概念,即线性表的顺序存储结构,并提供了用Python实现顺序表的代码示例。该实现包括了初始化、判断空全满、获取与设置元素、按值查找元素位置、统计元素个数、插入、删除、输出和销毁等操作。通过这个实现,读者可以更好地理解顺序表的工作原理及其在实际编程中的应用。
摘要由CSDN通过智能技术生成

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

8af5e45869e353cc8464203c0d5a7979.png

下面是顺序表的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、付费专栏及课程。

余额充值