Python数据结构之双向链表的定义与使用方法示例


Posted in Python onJanuary 16, 2018

本文实例讲述了Python数据结构之双向链表的定义与使用方法。分享给大家供大家参考,具体如下:

和单链表类似,只不过是增加了一个指向前面一个元素的指针而已。

示意图:

Python数据结构之双向链表的定义与使用方法示例

python 实现代码:

#!/usr/bin/python
# -*- coding: utf-8 -*-
class Node(object):
  def __init__(self,val,p=0):
    self.data = val
    self.next = p
    self.prev = p
class LinkList(object):
  def __init__(self):
    self.head = 0
  def __getitem__(self, key):
    if self.is_empty():
      print 'linklist is empty.'
      return
    elif key <0 or key > self.getlength():
      print 'the given key is error'
      return
    else:
      return self.getitem(key)
  def __setitem__(self, key, value):
    if self.is_empty():
      print 'linklist is empty.'
      return
    elif key <0 or key > self.getlength():
      print 'the given key is error'
      return
    else:
      self.delete(key)
      return self.insert(key)
  def initlist(self,data):
    self.head = Node(data[0])
    p = self.head
    for i in data[1:]:
      node = Node(i)
      p.next = node
      node.prev = p
      p = p.next
  def getlength(self):
    p = self.head
    length = 0
    while p!=0:
      length+=1
      p = p.next
    return length
  def is_empty(self):
    if self.getlength() ==0:
      return True
    else:
      return False
  def clear(self):
    self.head = 0
  def append(self,item):
    q = Node(item)
    if self.head ==0:
      self.head = q
    else:
      p = self.head
      while p.next!=0:
        p = p.next
      p.next = q
      q.prev = p
  def getitem(self,index):
    if self.is_empty():
      print 'Linklist is empty.'
      return
    j = 0
    p = self.head
    while p.next!=0 and j <index:
      p = p.next
      j+=1
    if j ==index:
      return p.data
    else:
      print 'target is not exist!'
  def insert(self,index,item):
    if self.is_empty() or index<0 or index >self.getlength():
      print 'Linklist is empty.'
      return
    if index ==0:
      q = Node(item,self.head)
      self.head = q
    p = self.head
    post = self.head
    j = 0
    while p.next!=0 and j<index:
      post = p
      p = p.next
      j+=1
    if index ==j:
      q = Node(item,p)
      post.next = q
      q.prev = post
      q.next = p
      p.prev = q
  def delete(self,index):
    if self.is_empty() or index<0 or index >self.getlength():
      print 'Linklist is empty.'
      return
    if index ==0:
      q = Node(item,self.head)
      self.head = q
    p = self.head
    post = self.head
    j = 0
    while p.next!=0 and j<index:
      post = p
      p = p.next
      j+=1
    if index ==j:
      post.next = p.next
      p.next.prev = post
  def index(self,value):
    if self.is_empty():
      print 'Linklist is empty.'
      return
    p = self.head
    i = 0
    while p.next!=0 and not p.data ==value:
      p = p.next
      i+=1
    if p.data == value:
      return i
    else:
      return -1
l = LinkList()
l.initlist([1,2,3,4,5])
print "三水点靠木测试结果:"
print l.getitem(4)
l.append(6)
print l.getitem(5)
l.insert(4,40)
print l.getitem(3)
print l.getitem(4)
print l.getitem(5)
l.delete(5)
print l.getitem(5)
l.index(5)

结果为;

Python数据结构之双向链表的定义与使用方法示例

和单链表结果一样。

PS:双向链表就是将链表首尾相接。

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
浅谈python中copy和deepcopy中的区别
Oct 23 Python
对python .txt文件读取及数据处理方法总结
Apr 23 Python
Python中的heapq模块源码详析
Jan 08 Python
python 字符串常用方法汇总详解
Sep 16 Python
python opencv将表格图片按照表格框线分割和识别
Oct 30 Python
浅谈python3打包与拆包在函数的应用详解
May 02 Python
利用PyQt5+Matplotlib 绘制静态/动态图的实现代码
Jul 13 Python
PyTorch实现重写/改写Dataset并载入Dataloader
Jul 14 Python
python如何停止递归
Sep 09 Python
python 爬虫网页登陆的简单实现
Nov 30 Python
python自动统计zabbix系统监控覆盖率的示例代码
Apr 03 Python
Python Pandas常用函数方法总结
Jun 15 Python
python+pillow绘制矩阵盖尔圆简单实例
Jan 16 #Python
Python面向对象编程之继承与多态详解
Jan 16 #Python
Python基于socket实现简单的即时通讯功能示例
Jan 16 #Python
python中将字典形式的数据循环插入Excel
Jan 16 #Python
python+tkinter编写电脑桌面放大镜程序实例代码
Jan 16 #Python
详解python函数传参是传值还是传引用
Jan 16 #Python
Python+tkinter使用80行代码实现一个计算器实例
Jan 16 #Python
You might like
NOD32 v2.70.32 简体中文封装版 提供下载了
2007/02/27 PHP
PHP使用PDO连接ACCESS数据库
2015/03/05 PHP
php上传功能集后缀名判断和随机命名(强力推荐)
2015/09/10 PHP
PHP不使用递归的无限级分类简单实例
2016/11/05 PHP
javascript 获取元素位置的快速方法 getBoundingClientRect()
2009/11/26 Javascript
javascript当onmousedown、onmouseup、onclick同时应用于同一个标签节点Element
2010/01/05 Javascript
JavaScript通过RegExp实现客户端验证处理程序
2013/05/07 Javascript
鼠标经过tr时,改变tr当前背景颜色
2014/01/13 Javascript
利用Keydown事件阻止用户输入实现代码
2014/03/11 Javascript
js实现的简单radio背景颜色选择器代码
2015/08/18 Javascript
JS表格组件神器bootstrap table详解(基础版)
2015/12/08 Javascript
在IE8上JS实现combobox支持拼音检索功能
2016/05/23 Javascript
JS原型对象的创建方法详解
2016/06/16 Javascript
微信小程序 picker 组件详解及简单实例
2017/01/10 Javascript
微信小程序使用Promise简化回调
2018/02/06 Javascript
echarts整合多个类似option的方法实例
2018/07/10 Javascript
Vue页面跳转动画效果的实现方法
2018/09/23 Javascript
如何检查一个对象是否为空
2019/04/11 Javascript
vue-video-player视频播放器使用配置详解
2020/10/23 Javascript
pandas apply 函数 实现多进程的示例讲解
2018/04/20 Python
python实现批量解析邮件并下载附件
2018/06/19 Python
Python实现手写一个类似django的web框架示例
2018/07/20 Python
Python绘制的二项分布概率图示例
2018/08/22 Python
Python面向对象类编写细节分析【类,方法,继承,超类,接口等】
2019/01/05 Python
Flask框架重定向,错误显示,Responses响应及Sessions会话操作示例
2019/08/01 Python
CSS3轻松实现圆角效果
2017/11/09 HTML / CSS
css3模拟jq点击事件的实例代码
2017/07/06 HTML / CSS
菲律宾旅游网站:Expedia菲律宾
2017/10/11 全球购物
社区学习雷锋活动总结
2014/04/25 职场文书
2014年个人工作总结范文
2014/11/07 职场文书
2014年安全管理工作总结
2014/12/01 职场文书
优秀大学生自荐信
2015/03/26 职场文书
被告代理词范文
2015/05/25 职场文书
致三级跳运动员加油稿
2015/07/21 职场文书
2016年公务员六五普法心得体会
2016/01/21 职场文书
element tree树形组件回显数据问题解决
2022/08/14 Javascript