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 相关文章推荐
初步剖析C语言编程中的结构体
Jan 16 Python
一个基于flask的web应用诞生 使用模板引擎和表单插件(2)
Apr 11 Python
python绘制简单折线图代码示例
Dec 19 Python
Python安装图文教程 Pycharm安装教程
Mar 27 Python
Python实现的凯撒密码算法示例
Apr 12 Python
python将字符串以utf-8格式保存在txt文件中的方法
Oct 30 Python
Python中如何使用if语句处理列表实例代码
Feb 24 Python
解决python3中的requests解析中文页面出现乱码问题
Apr 19 Python
Django框架orM与自定义SQL语句混合事务控制操作
Jun 27 Python
Python常用库大全及简要说明
Jan 17 Python
浅谈Tensorflow 动态双向RNN的输出问题
Jan 20 Python
基于keras输出中间层结果的2种实现方式
Jan 24 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
PHP实现删除字符串中任何字符的函数
2015/08/11 PHP
PHP 微信扫码支付源代码(推荐)
2016/11/03 PHP
PHP遍历目录文件的常用方法小结
2017/02/03 PHP
PHP反射机制原理与用法详解
2017/02/15 PHP
js各种验证文本框输入格式(正则表达式)
2010/10/22 Javascript
js下判断 iframe 是否加载完成的完美方法
2010/10/26 Javascript
jqgrid 编辑添加功能详细解析
2013/11/08 Javascript
js和jquery中循环的退出和继续学习记录
2014/09/06 Javascript
JavaScript lastIndexOf方法入门实例(计算指定字符在字符串中最后一次出现的位置)
2014/10/17 Javascript
js实现简单选项卡与自动切换效果的方法
2015/04/10 Javascript
js获取form的方法
2015/05/06 Javascript
实例代码详解jquery.slides.js
2015/11/16 Javascript
原生js实现百叶窗效果及原理介绍
2016/04/12 Javascript
JavaScript进阶练习及简单实例分析
2016/06/03 Javascript
JS实现含有中文字符串的友好截取功能分析
2017/03/13 Javascript
React利用插件和不用插件实现双向绑定的方法详解
2017/07/03 Javascript
Javascript 之封装(Package)
2018/09/14 Javascript
vue 实现路由跳转时更改页面title
2019/11/05 Javascript
JavaScript本地储存:localStorage、sessionStorage、cookie的使用
2020/10/13 Javascript
原生微信小程序开发中 redux 的使用详解
2021/02/18 Javascript
python调用shell的方法
2013/11/20 Python
python搭建微信公众平台
2016/02/09 Python
python去掉行尾的换行符方法
2017/01/04 Python
利用Python找出序列中出现最多的元素示例代码
2017/12/08 Python
Python使用lambda表达式对字典排序操作示例
2019/07/25 Python
python pprint模块中print()和pprint()两者的区别
2020/02/10 Python
举例讲解Python装饰器
2020/12/24 Python
全球领先的各类汽车配件零售商:Advance Auto Parts
2016/08/26 全球购物
先进个人事迹材料
2014/01/25 职场文书
毕业典礼演讲稿
2014/05/13 职场文书
大二学生学年自我鉴定
2014/09/12 职场文书
大学生自荐信怎么写
2015/03/26 职场文书
建国70周年的心得体会(2篇)
2019/09/20 职场文书
导游词之平津战役纪念馆
2019/11/04 职场文书
浅谈JS的二进制家族
2021/05/09 Javascript
什么是Python装饰器?如何定义和使用?
2022/04/11 Python