Python中顺序表的实现简单代码分享


Posted in Python onJanuary 09, 2018

顺序表python版的实现(部分功能未实现)

结果展示:

Python中顺序表的实现简单代码分享

代码示例:

#!/usr/bin/env python
# -*- coding:utf-8 -*-

class SeqList(object):
 def __init__(self, max=8):
  self.max = max  #创建默认为8
  self.num = 0
  self.date = [None] * self.max
  #list()会默认创建八个元素大小的列表,num=0,并有链接关系
  #用list实现list有些荒谬,全当练习
  #self.last = len(self.date)
  #当列表满时,扩建的方式省略
 def is_empty(self):
  return self.num is 0

 def is_full(self):
  return self.num is self.max

 #获取某个位置的元素
 def __getitem__(self, key):
  if not isinstance(key, int):
   raise TypeError
  if 0<= key < self.num:
   return self.date[key]
  else:
   #表为空或者索引超出范围都会引发索引错误
   raise IndexError

 #设置某个位置的元素
 def __setitem__(self, key, value):
  if not isinstance(key, int):
   raise TypeError
  #只能访问列表里已有的元素,self.num=0时,一个都不能访问,self.num=1时,只能访问0
  if 0<= key < self.num:
   self.date[key] = value #该位置无元素会发生错误
  else:
   raise IndexError

 def clear(self):
  self.__init__()

 def count(self):
  return self.num

 def __len__(self):
  return self.num

 #加入元素的方法 append()和insert()
 def append(self,value):
  if self.is_full():
   #等下扩建列表
   print("list is full")
   return
  else:
   self.date[self.num] = value
   self.num += 1

 def insert(self,key,value):
  if not isinstance(key, int):
   raise TypeError
  if key<0: #暂时不考虑负数索引
   raise IndexError
  #当key大于元素个数时,默认尾部插入
  if key>=self.num:
   self.append(value)
  else:
   #移动key后的元素
   for i in range(self.num, key, -1):
    self.date[i] = self.date[i-1]
   #赋值
   self.date[key] = value
   self.num += 1

 #删除元素的操作
 def pop(self,key=-1):
  if not isinstance(key, int):
   raise TypeError
  if self.num-1 < 0:
   raise IndexError("pop from empty list")
  elif key == -1:
   #原来的数还在,但列表不识别他
   self.num -= 1
  else:
   for i in range(key,self.num-1):
    self.date[i] = self.date[i+1]
   self.num -= 1

 def index(self,value,start=0):
  for i in range(start, self.num):
   if self.date[i] == value:
    return i
  #没找到
  raise ValueError("%d is not in the list" % value)

 #列表反转
 def reverse(self):
  i,j = 0, self.num - 1
  while i<j:
   self.date[i], self.date[j] = self.date[j], self.date[i]
   i,j = i+1, j-1

if __name__=="__main__":
 a = SeqList()
 print(a.date)
 #num == 0
 print(a.is_empty())
 a.append(0)
 a.append(1)
 a.append(2)
 print(a.date)
 print(a.num)
 print(a.max)
 a.insert(1,6)
 print(a.date)
 a[1] = 5
 print(a.date)
 print(a.count())

 print("返回值为2(第一次出现)的索引:", a.index(2, 1))
 print("====")
 t = 1
 if t:
  a.pop(1)
  print(a.date)
  print(a.num)
 else:
  a.pop()
  print(a.date)
  print(a.num)
 print("========")
 print(len(a))

 a.reverse()
 print(a.date)
 """
 print(a.is_full())
 a.clear()
 print(a.date)
 print(a.count())
 """

有关于Python数据结构中顺序表的实现,大家也可以参考本站的另一篇文章Python数据结构之顺序表的实现代码示例,当中有对顺序表略微详细的介绍。小编对此知识点理解不够透彻,以后还会继续研究的。

以上就是本文关于Python中顺序表的实现简单代码分享的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

Python 相关文章推荐
python中readline判断文件读取结束的方法
Nov 08 Python
使用python实现正则匹配检索远端FTP目录下的文件
Mar 25 Python
Python判断列表是否已排序的各种方法及其性能分析
Jun 20 Python
python 简单搭建阻塞式单进程,多进程,多线程服务的实例
Nov 01 Python
Django forms组件的使用教程
Oct 08 Python
Python常见的pandas用法demo示例
Mar 16 Python
python装饰器简介---这一篇也许就够了(推荐)
Apr 01 Python
手把手教你使用Python创建微信机器人
Apr 29 Python
Pycharm运行加载文本出现错误的解决方法
Jun 27 Python
Python PIL读取的图像发生自动旋转的实现方法
Jul 05 Python
python文件读写代码实例
Oct 21 Python
Python中免验证跳转到内容页的实例代码
Oct 23 Python
python中set()函数简介及实例解析
Jan 09 #Python
Python中摘要算法MD5,SHA1简介及应用实例代码
Jan 09 #Python
深入了解Python中pop和remove的使用方法
Jan 09 #Python
Python使用smtp和pop简单收发邮件完整实例
Jan 09 #Python
Numpy中stack(),hstack(),vstack()函数用法介绍及实例
Jan 09 #Python
详解python使用Nginx和uWSGI来运行Python应用
Jan 09 #Python
Python numpy实现数组合并实例(vstack,hstack)
Jan 09 #Python
You might like
SSI指令
2006/11/25 PHP
PHP防止注入攻击实例分析
2014/11/03 PHP
PHP防止刷新重复提交页面的示例代码
2015/11/11 PHP
PHP Try-catch 语句使用技巧
2016/02/28 PHP
php mysql操作mysql_connect连接数据库实例详解
2016/12/26 PHP
对laravel的session获取与存取方法详解
2019/10/08 PHP
新浪中用来显示flash的函数
2007/04/02 Javascript
javascript 关于# 和 void的区别分析
2009/10/26 Javascript
jQuery产品间断向下滚动效果核心代码
2014/05/08 Javascript
javascript检查浏览器是否支持flash的实现代码
2014/08/14 Javascript
AngularJS学习笔记之TodoMVC的分析
2015/02/22 Javascript
JavaScript常用脚本汇总(一)
2015/03/04 Javascript
javascript简单比较日期大小的方法
2016/01/05 Javascript
利用JS对iframe父子(内外)页面进行操作的方法教程
2017/06/15 Javascript
详解nodejs实现本地上传图片并预览功能(express4.0+)
2017/06/28 NodeJs
trackingjs+websocket+百度人脸识别API实现人脸签到
2018/11/26 Javascript
微信小程序保持session会话的方法
2020/03/20 Javascript
原生JS实现拖拽功能
2020/12/16 Javascript
Python字符串拼接、截取及替换方法总结分析
2016/04/13 Python
python自带的http模块详解
2016/11/06 Python
python基础练习之几个简单的游戏
2017/11/10 Python
python判断列表的连续数字范围并分块的方法
2018/11/16 Python
Python线上环境使用日志的及配置文件
2019/07/28 Python
Win10系统下安装labelme及json文件批量转化方法
2019/07/30 Python
基于python解线性矩阵方程(numpy中的matrix类)
2019/10/21 Python
pytorch::Dataloader中的迭代器和生成器应用详解
2020/01/03 Python
python百行代码自制电脑端网速悬浮窗的实现
2020/05/12 Python
Python计算信息熵实例
2020/06/18 Python
W3C公布最新的HTML5标准草案
2008/10/17 HTML / CSS
Parfumdreams芬兰:购买香水和化妆品
2021/02/13 全球购物
园林资料员岗位职责
2013/12/30 职场文书
晚会邀请函范文
2014/01/24 职场文书
咖啡店创业计划书
2014/08/15 职场文书
安阳殷墟导游词
2015/02/10 职场文书
大卫科波菲尔读书笔记
2015/06/30 职场文书
VUE解决跨域问题Access to XMLHttpRequest at
2022/05/06 Vue.js