python实现顺序表的简单代码

作者:lonely_square_three 时间:2022-01-10 05:03:20 

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

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.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__()

来源:https://blog.csdn.net/xzfreewind/article/details/74834226

标签:python,顺序表
0
投稿

猜你喜欢

  • asp删除mssql数据库中没有记录的图片代码

    2011-03-11 11:22:00
  • Python统计python文件中代码,注释及空白对应的行数示例【测试可用】

    2023-04-30 00:11:19
  • python实现简单名片管理系统

    2023-06-13 08:03:12
  • 用面包屑来简化多层的tabs

    2011-06-16 20:32:54
  • 线程安全及Python中的GIL原理分析

    2022-09-06 11:16:20
  • Django配置kafka消息队列的实现

    2023-07-19 00:49:27
  • 改变链接,让别人永远找不到你的程序

    2008-09-13 18:57:00
  • python 获取list特定元素下标的实例讲解

    2021-12-13 23:54:41
  • asp解决防止表单重复提交的方法

    2007-10-19 18:40:00
  • HTML5 第二份草案发布

    2008-06-17 17:42:00
  • Python通过TensorFlow卷积神经网络实现猫狗识别

    2023-09-29 10:59:56
  • 人工神经网络算法知识点总结

    2023-05-16 11:36:06
  • 详解Oracle 中实现数据透视表的几种方法

    2023-07-24 03:45:04
  • Python爬虫定时计划任务的几种常见方法(推荐)

    2021-06-02 02:05:39
  • Python学习之yaml文件的读取详解

    2023-04-20 14:06:42
  • Python 实现简单的电话本功能

    2021-11-16 09:47:58
  • 浅谈在JupyterNotebook下导入自己的模块的问题

    2023-03-16 11:28:36
  • PDO::setAttribute讲解

    2023-06-05 18:04:23
  • 推荐系统MostPopular算法的Python实现方式

    2022-04-21 14:44:24
  • 基于ORA-12170 TNS 连接超时解决办法详解

    2023-06-30 18:18:30
  • asp之家 网络编程 m.aspxhome.com