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 pickle类库介绍(对象序列化和反序列化)
Nov 21 Python
Python的字典和列表的使用中一些需要注意的地方
Apr 24 Python
使用Python编写提取日志中的中文的脚本的方法
Apr 30 Python
Pyhton中单行和多行注释的使用方法及规范
Oct 11 Python
python读取文件名称生成list的方法
Apr 27 Python
Django中的forms组件实例详解
Nov 08 Python
Python 通过微信控制实现app定位发送到个人服务器再转发微信服务器接收位置信息
Aug 05 Python
python求质数列表的例子
Nov 24 Python
Django实现whoosh搜索引擎使用jieba分词
Apr 08 Python
Python中使用socks5设置全局代理的方法示例
Apr 15 Python
django 利用Q对象与F对象进行查询的实现
May 15 Python
python爬取新闻门户网站的示例
Apr 25 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代码中使用换行及(\n或\r\n和br)的应用
2013/02/02 PHP
PDO的安全处理与事物处理方法
2016/10/31 PHP
JavaScript 模仿vbs中的 DateAdd() 函数的代码
2007/08/13 Javascript
用tip解决Ext列宽度不够的问题
2008/12/13 Javascript
老鱼 浅谈javascript面向对象编程
2010/03/04 Javascript
Jquery实现页面加载时弹出对话框代码
2013/04/19 Javascript
为什么JS中eval处理JSON数据要加括号
2015/04/13 Javascript
JS+CSS实现的日本门户网站经典选项卡导航效果
2015/09/27 Javascript
原生js实现ajax方法(超简单)
2016/09/20 Javascript
vue.js指令v-for使用及索引获取
2016/11/03 Javascript
详解js的六大数据类型
2016/12/27 Javascript
Javascript面试经典套路reduce函数查重
2017/03/23 Javascript
js和jquery中获取非行间样式
2017/05/05 jQuery
关于javascript sort()排序你可能忽略的一点理解
2017/07/18 Javascript
hammer.js实现图片手势放大效果
2017/08/29 Javascript
javascript 中模板方法单例的实现方法
2017/10/17 Javascript
Json实现传值到后台代码实例
2020/06/30 Javascript
vue 自定指令生成uuid滚动监听达到tab表格吸顶效果的代码
2020/09/16 Javascript
Java 生成随机字符的示例代码
2021/01/13 Javascript
[00:12]2018DOTA2亚洲邀请赛 sylar表现SOLO技艺
2018/04/06 DOTA
linux下安装easy_install的方法
2013/02/10 Python
Python面向对象程序设计之继承与多继承用法分析
2018/07/13 Python
对python函数签名的方法详解
2019/01/22 Python
pygame实现俄罗斯方块游戏(AI篇2)
2019/10/29 Python
keras中的卷积层&amp;池化层的用法
2020/05/22 Python
CSS3 animation ? steps 函数详解
2019/08/30 HTML / CSS
Yahoo-PHP面试题3
2012/01/14 面试题
一组SQL面试题
2016/02/15 面试题
介绍一下Java的事务处理
2012/12/07 面试题
数据员岗位职责
2013/11/19 职场文书
业务部经理岗位职责
2014/01/04 职场文书
临床护士自荐信
2014/01/31 职场文书
新员工入职欢迎词
2015/01/23 职场文书
如何才能写好调研报告?
2019/07/03 职场文书
导游词范文之颐和园/重庆/云台山
2019/09/10 职场文书
MySQL 8.0 之不可见列的基本操作
2021/05/20 MySQL