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

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

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

python顺序表代码_python实现顺序表的简单代码相关推荐

  1. python输出箭头代码_python matplotlib 注释文本箭头简单代码示例

    注释文本箭头 结果展示: 完整代码示例: import numpy as np import matplotlib.pyplot as plt fig,ax = plt.subplots(figsiz ...

  2. python爬虫知乎代码_python爬虫知乎的简单代码实现

    随着时代的发展,我们很依赖网络帮助我们解决问题,遇到什么问题就会先百度.除了百度,现在大多数人还会选择通过知乎来解决问题.知乎类似于一个论坛,讨论度比百度高一些,那你知道如何用python爬虫爬知乎网 ...

  3. python导入txt文件并绘图-Python实现读取txt文件并画三维图简单代码示例

    记忆力差的孩子得勤做笔记! 刚接触python,最近又需要画一个三维图,然后就找了一大堆资料,看的人头昏脑胀的,今天终于解决了!好了,废话不多说,直接上代码! #由三个一维坐标画三维散点 #codin ...

  4. python读取txt文件代码-Python实现读取txt文件并画三维图简单代码示例

    记忆力差的孩子得勤做笔记! 刚接触python,最近又需要画一个三维图,然后就找了一大堆资料,看的人头昏脑胀的,今天终于解决了!好了,废话不多说,直接上代码! #由三个一维坐标画三维散点 #codin ...

  5. python编九九乘法表儿歌_python 九九乘法表!小练习

    # 1*1 = 1 # 1*2 = 2 2*2 = 4 # 1*3 = 3 2*3 = 6 3*3 = 9 i = 1 j = 1 for j in range(1,10): for i in ran ...

  6. python乘法表图片_python的乘法表

    简单的python程序实现99乘法口诀表 刚开始学习使用python,简单的实现一个99乘法口诀表: 1 2 3 4 5 6 7 8 #!/usr/bin/env python # for i in  ...

  7. python怎样实现多表连接_Python Day45多表连接查询

    一.多表连接查询 1 交叉连接:不适用任何匹配条件.生成笛卡尔积 mysql> select * fromemployee,department;+----+------------+----- ...

  8. python 写入第二列_python读写Excel表格的实例代码(简单实用)

    这篇文章主要介绍了python读写Excel表格的方法,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下.需要先安装两个库:pip install xlrd.pip ...

  9. python操作数据库教程_Python连接mysql数据库及简单增删改查操作示例代码

    1.安装pymysql 进入cmd,输入 pip install pymysql: 2.数据库建表 在数据库中,建立一个简单的表,如图: 3.简单操作 3.1查询操作 #coding=utf-8 #连 ...

  10. python贪吃蛇程序_Python 实现 贪吃蛇大作战 代码分享

    感觉游戏审核新政实施后,国内手游市场略冷清,是不是各家的新游戏都在排队等审核.媒体们除了之前竞相追捧<Pokemon Go>热闹了一把,似乎也听不到什么声音了.直到最近几天,突然听见好几人 ...

最新文章

  1. 图像边缘检测之拉普拉斯(Laplacian)C++实现
  2. 微软宣布Azure Migrate和Site Recovery服务增强功能
  3. kafka教程_2018年机器学习趋势与Apache Kafka生态系统结合
  4. 惊了!Chrome浏览器竟然自带的一款恐龙游戏【免下载】
  5. IBastis配置实例
  6. window10 java 设置环境变量
  7. 基于android的交流平台,基于Android的移动学习交流平台的设计与实现
  8. Tensorflow卷积神经网络
  9. java 增 删 查 改_如何对java链表进行增、删、查、改操作
  10. c++之string类详解
  11. WPF学习之数据绑定
  12. 电阻中联分压电路的计算
  13. 统计分析之参数检验与非参数检验、匹配样本与独立样本、2样本与K样本介绍----附SPSS操作指南
  14. Odoo-----在Form视图中添加Chatter
  15. python打印皮卡丘步骤_编程作战丨如何利用python绘制可爱皮卡丘?
  16. java 路由框架_使用Spring框架和AOP实现动态路由
  17. hangfire入门
  18. 计算机课说话检查200字,上课说话200字检讨书
  19. php 统计 app 下载量,如何做一个算法估算出一个不定时抓取到一个APP每天的下载量...
  20. JAVA十六进制数据转换

热门文章

  1. 数据挖掘Apriori算法
  2. 华东交通大学计算机调剂,华东交通大学2018考研调剂信息
  3. mysql 分时统计_mysql中数据统计的技巧备忘录
  4. 滚动条滚动加载图片或则请求的实现方法
  5. SQL基础语法与规则
  6. 七牛云图片存储---Java
  7. 数据结构实验4:C++实现循环队列
  8. protected private public 的区别
  9. 20150127--Session入库
  10. 在script所在位置插入内容