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 变量类型及命名规则介绍
Jun 08 Python
python进阶教程之循环对象
Aug 30 Python
Python实现读取txt文件并转换为excel的方法示例
May 17 Python
Python使用Selenium模块实现模拟浏览器抓取淘宝商品美食信息功能示例
Jul 18 Python
Python3实现的简单工资管理系统示例
Mar 12 Python
python代码 FTP备份交换机配置脚本实例解析
Aug 01 Python
win10下安装Anaconda的教程(python环境+jupyter_notebook)
Oct 23 Python
python实现多进程按序号批量修改文件名的方法示例
Dec 30 Python
Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法
Mar 20 Python
Python 抓取数据存储到Redis中的操作
Jul 16 Python
Python发送邮件实现基础解析
Aug 14 Python
python中requests模拟登录的三种方式(携带cookie/session进行请求网站)
Nov 17 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语法速查表
2006/12/06 PHP
PHP获取和操作配置文件php.ini的几个函数介绍
2013/06/24 PHP
PHP中使用sleep造成mysql读取失败的案例和解决方法
2014/08/21 PHP
详解Grunt插件之LiveReload实现页面自动刷新(两种方案)
2015/07/31 PHP
适合PHP初学者阅读的4本经典书籍
2016/09/23 PHP
php通过header发送自定义数据方法
2018/01/18 PHP
JS 建立对象的方法
2007/04/21 Javascript
禁用页面部分JavaScript方法的具体实现
2013/07/31 Javascript
jquery固定底网站底部菜单效果
2013/08/13 Javascript
jquery查找tr td 示例模拟
2014/05/08 Javascript
JavaScript实现简单图片滚动附源码下载
2014/06/17 Javascript
js调试工具console.log()方法查看js代码的执行情况
2014/08/08 Javascript
jQuery中:only-child选择器用法实例
2015/01/03 Javascript
javascript检测移动设备横竖屏
2016/05/21 Javascript
jQuery UI仿淘宝搜索下拉列表功能
2017/01/10 Javascript
JS高仿抛物线加入购物车特效实现代码
2017/02/20 Javascript
微信小程序结合mock.js实现后台模拟及调试
2019/03/28 Javascript
[01:32]2016国际邀请赛中国区预选赛CDEC战队教练采访
2016/06/26 DOTA
[01:15:00]LGD vs Mineski Supermajor 胜者组 BO3 第一场 6.5
2018/06/06 DOTA
pymongo为mongodb数据库添加索引的方法
2015/05/11 Python
在python中使用正则表达式查找可嵌套字符串组
2017/10/24 Python
Python编程产生非均匀随机数的几种方法代码分享
2017/12/13 Python
Python爬虫实现爬取百度百科词条功能实例
2019/04/05 Python
Python替换月份为英文缩写的实现方法
2019/07/15 Python
python框架flask表单实现详解
2019/11/04 Python
python 下载文件的多种方法汇总
2020/11/17 Python
vivo智能手机官方商城:vivo
2016/09/22 全球购物
银河香水:Galaxy Perfume
2019/03/25 全球购物
总监职责范文
2013/11/09 职场文书
青年志愿者先进事迹
2014/05/06 职场文书
2014矛盾纠纷排查调处工作总结
2014/12/09 职场文书
骨干教师考核评语
2014/12/31 职场文书
经典搞笑版检讨书
2015/02/19 职场文书
怎样写辞职信
2015/02/27 职场文书
运动员入场前导词
2015/07/20 职场文书
2019公司借款合同范本2篇!
2019/07/24 职场文书