Python实现的单向循环链表功能示例


Posted in Python onNovember 10, 2017

本文实例讲述了Python实现的单向循环链表功能。分享给大家供大家参考,具体如下:

概述:

单向循环链表是指在单链表的基础上,表的最后一个元素指向链表头结点,不再是为空。

Python实现的单向循环链表功能示例

由图可知,单向循环链表的判断条件不再是表为空了,而变成了是否到表头。

操作

is_empty() 判断链表是否为空
length() 返回链表的长度
travel() 遍历
add(item) 在头部添加一个节点
append(item) 在尾部添加一个节点
insert(pos, item) 在指定位置pos添加节点
remove(item) 删除一个节点
search(item) 查找节点是否存在

具体代码:

class Node(object):
  """节点"""
  def __init__(self, item):
    self.item = item
    self.next = None
class SinCycLinkedlist(object):
  """单向循环链表"""
  def __init__(self):
    self._head = None
  def is_empty(self):
    """判断链表是否为空"""
    return self._head == None
  def length(self):
    """返回链表的长度"""
    # 如果链表为空,返回长度0
    if self.is_empty():
      return 0
    count = 1
    cur = self._head
    while cur.next != self._head:
      count += 1
      cur = cur.next
    return count
  def travel(self):
    """遍历链表"""
    if self.is_empty():
      return
    cur = self._head
    print cur.item,
    while cur.next != self._head:
      cur = cur.next
      print cur.item,
    print ""
  def add(self, item):
    """头部添加节点"""
    node = Node(item)
    if self.is_empty():
      self._head = node
      node.next = self._head
    else:
      #添加的节点指向_head
      node.next = self._head
      # 移到链表尾部,将尾部节点的next指向node
      cur = self._head
      while cur.next != self._head:
        cur = cur.next
      cur.next = node
      #_head指向添加node的
      self._head = node
  def append(self, item):
    """尾部添加节点"""
    node = Node(item)
    if self.is_empty():
      self._head = node
      node.next = self._head
    else:
      # 移到链表尾部
      cur = self._head
      while cur.next != self._head:
        cur = cur.next
      # 将尾节点指向node
      cur.next = node
      # 将node指向头节点_head
      node.next = self._head
  def insert(self, pos, item):
    """在指定位置添加节点"""
    if pos <= 0:
      self.add(item)
    elif pos > (self.length()-1):
      self.append(item)
    else:
      node = Node(item)
      cur = self._head
      count = 0
      # 移动到指定位置的前一个位置
      while count < (pos-1):
        count += 1
        cur = cur.next
      node.next = cur.next
      cur.next = node
  def remove(self, item):
    """删除一个节点"""
    # 若链表为空,则直接返回
    if self.is_empty():
      return
    # 将cur指向头节点
    cur = self._head
    pre = None
    # 若头节点的元素就是要查找的元素item
    if cur.item == item:
      # 如果链表不止一个节点
      if cur.next != self._head:
        # 先找到尾节点,将尾节点的next指向第二个节点
        while cur.next != self._head:
          cur = cur.next
        # cur指向了尾节点
        cur.next = self._head.next
        self._head = self._head.next
      else:
        # 链表只有一个节点
        self._head = None
    else:
      pre = self._head
      # 第一个节点不是要删除的
      while cur.next != self._head:
        # 找到了要删除的元素
        if cur.item == item:
          # 删除
          pre.next = cur.next
          return
        else:
          pre = cur
          cur = cur.next
      # cur 指向尾节点
      if cur.item == item:
        # 尾部删除
        pre.next = cur.next
  def search(self, item):
    """查找节点是否存在"""
    if self.is_empty():
      return False
    cur = self._head
    if cur.item == item:
      return True
    while cur.next != self._head:
      cur = cur.next
      if cur.item == item:
        return True
    return False
if __name__ == "__main__":
  ll = SinCycLinkedlist()
  ll.add(1)
  ll.add(2)
  ll.append(3)
  ll.insert(2, 4)
  ll.insert(4, 5)
  ll.insert(0, 6)
  print "length:",ll.length()
  ll.travel()
  print ll.search(3)
  print ll.search(7)
  ll.remove(1)
  print "length:",ll.length()
  ll.travel()

运行结果:

Python实现的单向循环链表功能示例

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

Python 相关文章推荐
python list使用示例 list中找连续的数字
Jan 27 Python
Java Web开发过程中登陆模块的验证码的实现方式总结
May 25 Python
python+django加载静态网页模板解析
Dec 12 Python
python 字典中文key处理,读取,比较方法
Jul 06 Python
Python常用的json标准库
Feb 19 Python
PyQt5实现从主窗口打开子窗口的方法
Jun 19 Python
python代码实现逻辑回归logistic原理
Aug 07 Python
基于MSELoss()与CrossEntropyLoss()的区别详解
Jan 02 Python
TensorFlow 显存使用机制详解
Feb 03 Python
python读取配置文件方式(ini、yaml、xml)
Apr 09 Python
解决jupyter notebook打不开无反应 浏览器未启动的问题
Apr 10 Python
Python数据清洗工具之Numpy的基本操作
Apr 22 Python
Python3中的列表,元组,字典,字符串相关知识小结
Nov 10 #Python
浅谈Python处理PDF的方法
Nov 10 #Python
django开发教程之利用缓存文件进行页面缓存的方法
Nov 10 #Python
python使用邻接矩阵构造图代码示例
Nov 10 #Python
python先序遍历二叉树问题
Nov 10 #Python
简单了解OpenCV是个什么东西
Nov 10 #Python
python的文件操作方法汇总
Nov 10 #Python
You might like
PHP中将数组转成XML格式的实现代码
2011/08/08 PHP
php封装的mongodb操作类代码
2017/08/06 PHP
YII框架行为behaviors用法示例
2019/04/26 PHP
Mootools 1.2教程 定时器和哈希简介
2009/09/15 Javascript
javascript中创建对象的三种常用方法
2010/12/30 Javascript
Javascript Memoizer浅析
2014/10/16 Javascript
javascript中scrollTop详解
2015/04/13 Javascript
window.onload使用指南
2015/09/13 Javascript
DIV随滚动条滚动而滚动的实现代码【推荐】
2016/04/12 Javascript
基于jQuery实现音乐播放试听列表
2016/04/14 Javascript
javascript cookie用法基础教程(概念,设置,读取及删除)
2016/09/20 Javascript
JavaScript操作文件_动力节点Java学院整理
2017/06/30 Javascript
vue代码分割的实现(codesplit)
2018/11/13 Javascript
如何正确理解vue中的key详解
2019/11/02 Javascript
js实现移动端吸顶效果
2020/01/08 Javascript
浅谈webpack构建工具配置和常用插件总结
2020/05/11 Javascript
JavaScript 实现拖拽效果组件功能(兼容移动端)
2020/11/11 Javascript
[55:54]FNATIC vs EG 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
Python计算开方、立方、圆周率,精确到小数点后任意位的方法
2018/07/17 Python
pycharm在调试python时执行其他语句的方法
2018/11/29 Python
Python理解递归的方法总结
2019/01/28 Python
python flask解析json数据不完整的解决方法
2019/05/26 Python
基于Django ORM、一对一、一对多、多对多的全面讲解
2019/07/26 Python
JupyterNotebook设置Python环境的方法步骤
2019/12/03 Python
python3的UnicodeDecodeError解决方法
2019/12/20 Python
升级keras解决load_weights()中的未定义skip_mismatch关键字问题
2020/06/12 Python
Python logging日志库空间不足问题解决
2020/09/14 Python
Pycharm中使用git进行合作开发的教程详解
2020/11/17 Python
教师自荐书
2013/10/08 职场文书
入团者的自我评价分享
2013/12/02 职场文书
应届硕士毕业生自荐信
2014/05/26 职场文书
物业消防安全责任书
2014/07/23 职场文书
2015年实习班主任工作总结
2015/04/23 职场文书
2015年幼儿园卫生保健工作总结
2015/05/12 职场文书
python实现简单倒计时功能
2021/04/21 Python
详解使用内网穿透工具Ngrok代理本地服务
2022/03/31 Servers