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正则分组的应用
Nov 10 Python
Python对象的深拷贝和浅拷贝详解
Aug 25 Python
Python中的Numeric包和Numarray包使用教程
Apr 13 Python
Python的Scrapy爬虫框架简单学习笔记
Jan 20 Python
python如何统计序列中元素
Jul 31 Python
Python(Django)项目与Apache的管理交互的方法
May 16 Python
详解Python3中ceil()函数用法
Feb 19 Python
Python操作rabbitMQ的示例代码
Mar 19 Python
python命令行参数用法实例分析
Jun 25 Python
python pip源配置,pip配置文件存放位置的方法
Jul 12 Python
基于Django的乐观锁与悲观锁解决订单并发问题详解
Jul 31 Python
python 获取当前目录下的文件目录和文件名实例代码详解
Mar 10 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自定义函数实现代码
2011/12/30 PHP
PHP变量内存分配问题记录整理
2013/11/27 PHP
关于Laravel参数验证的一些疑与惑
2019/11/19 PHP
jQuery中setTimeout的几种使用方法小结
2013/04/07 Javascript
js confirm()方法的使用方法实例
2013/07/13 Javascript
js实现幻灯片播放图片示例代码
2013/11/07 Javascript
JavaScript实现图片轮播的方法
2015/07/31 Javascript
jquery根据td给相同tr下其他td赋值的实现方法
2016/10/05 Javascript
vue axios数据请求get、post方法及实例详解
2018/09/11 Javascript
JavaScript如何把两个数组对象合并过程解析
2019/10/10 Javascript
在Vue中使用Viser说明(基于AntV-G2可视化引擎)
2020/10/28 Javascript
原生JS实现音乐播放器
2021/01/26 Javascript
python格式化字符串实例总结
2014/09/28 Python
Python使用django搭建web开发环境
2017/06/09 Python
python3利用smtplib通过qq邮箱发送邮件方法示例
2017/12/03 Python
python 显示数组全部元素的方法
2018/04/19 Python
tensorflow 打印内存中的变量方法
2018/07/30 Python
python使用pandas抽样训练数据中某个类别实例
2020/02/28 Python
python中sympy库求常微分方程的用法
2020/04/28 Python
基于Python测试程序是否有错误
2020/05/16 Python
Python flask框架实现浏览器点击自定义跳转页面
2020/06/04 Python
PyQt5的QWebEngineView使用示例
2020/10/20 Python
css3的transform造成z-index无效解决方案
2014/12/04 HTML / CSS
Waterford加拿大官方网站:世界著名的水晶杯品牌
2016/11/01 全球购物
short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
2014/09/26 面试题
中专生自我鉴定书范文
2013/12/28 职场文书
《猫》教学反思
2014/02/26 职场文书
党的群众路线教育实践活动对照检查材料思想汇报
2014/09/19 职场文书
学生考试舞弊检讨书
2015/01/01 职场文书
教师节随笔
2015/08/15 职场文书
2016年度先进班组事迹材料
2016/03/01 职场文书
因个人工作失误检讨书
2019/06/21 职场文书
超市啤酒狂欢夜策划方案范文!
2019/07/03 职场文书
Java如何实现树的同构?
2021/06/22 Java/Android
在redisCluster中模糊获取key方式
2021/07/09 Redis
pycharm安装深度学习pytorch的d2l包失败问题解决
2022/03/25 Python