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实现颜色空间转换程序(Tkinter)
Dec 31 Python
Python 使用os.remove删除文件夹时报错的解决方法
Jan 13 Python
python先序遍历二叉树问题
Nov 10 Python
python 字典中取值的两种方法小结
Aug 02 Python
便捷提取python导入包的属性方法
Oct 15 Python
Python3实现从排序数组中删除重复项算法分析
Apr 03 Python
TensorFlow实现从txt文件读取数据
Feb 05 Python
python GUI库图形界面开发之PyQt5下拉列表框控件QComboBox详细使用方法与实例
Feb 27 Python
Python decorator拦截器代码实例解析
Apr 04 Python
Python 跨.py文件调用自定义函数说明
Jun 01 Python
使用python实现时间序列白噪声检验方式
Jun 03 Python
python字典进行运算原理及实例分享
Aug 02 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与已存在的Java应用程序集成
2006/10/09 PHP
php加密解密函数authcode的用法详细解析
2013/10/28 PHP
利用浏览器的Javascript控制台调试PHP程序
2014/01/08 PHP
浅析ThinkPHP中execute和query方法的区别
2014/06/13 PHP
Thinkphp中数据按分类嵌套循环实现方法
2014/10/30 PHP
php使用pear_smtp发送邮件
2016/04/15 PHP
复选框全选与全不选操作实现思路
2013/08/18 Javascript
jquery滚动特效集锦
2015/06/03 Javascript
AngularJs页面筛选标签小功能
2016/08/01 Javascript
利用Angularjs实现幻灯片效果
2016/09/07 Javascript
Javascript基础回顾之(二) js作用域
2017/01/31 Javascript
javascript中BOM基础知识总结
2017/02/14 Javascript
jQuery实现获取h1-h6标题元素值的方法
2017/03/06 Javascript
Express框架之connect-flash详解
2017/05/31 Javascript
jQuery+ajax读取json数据并按照价格排序示例
2018/03/28 jQuery
使用vue2实现带地区编号和名称的省市县三级联动效果
2018/11/05 Javascript
react同构实践之实现自己的同构模板
2019/03/13 Javascript
JavaScript字符串处理常见操作方法小结
2019/11/15 Javascript
vue组件内部引入外部js文件的方法
2020/01/18 Javascript
[10:24]郎朗助力完美“圣”典,天籁交织奏响序曲
2016/12/18 DOTA
Python之os操作方法(详解)
2017/06/15 Python
解决pip install的时候报错timed out的问题
2018/06/12 Python
详解opencv Python特征检测及K-最近邻匹配
2019/01/21 Python
Python 串口读写的实现方法
2019/06/12 Python
pyqt5 实现 下拉菜单 + 打开文件的示例代码
2019/06/20 Python
python里的单引号和双引号的有什么作用
2020/06/17 Python
Python如何实现后端自定义认证并实现多条件登陆
2020/06/22 Python
Django-simple-captcha验证码包使用方法详解
2020/11/28 Python
python自动化发送邮件实例讲解
2021/01/04 Python
H5调用相机拍照并压缩图片的实例代码
2017/07/20 HTML / CSS
Timberland德国官网:靴子、鞋子、衣服、夹克及配件
2019/12/10 全球购物
建筑工程毕业生自我鉴定
2014/01/14 职场文书
汉语言文学职业规划
2014/02/14 职场文书
贫困证明模板(3篇)
2014/09/16 职场文书
新年祝酒词大全
2015/08/11 职场文书
解决Navicat for Mysql连接报错1251的问题(连接失败)
2021/05/27 MySQL