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使用matplotlib的pie函数绘制饼状图功能示例
Jan 08 Python
用python处理图片实现图像中的像素访问
May 04 Python
python发送邮件脚本
May 22 Python
Python 获取div标签中的文字实例
Dec 20 Python
Django打印出在数据库中执行的语句问题
Jul 25 Python
Tensorflow 模型转换 .pb convert to .lite实例
Feb 12 Python
使用python从三个角度解决josephus问题的方法
Mar 27 Python
python中有帮助函数吗
Jun 19 Python
keras使用Sequence类调用大规模数据集进行训练的实现
Jun 22 Python
Python Tornado核心及相关原理详解
Jun 24 Python
通过代码简单了解django model序列化作用
Nov 12 Python
python如何调用php文件中的函数详解
Dec 29 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
浅析Mysql 数据回滚错误的解决方法
2013/08/05 PHP
PHP数据库万能引擎类adodb配置使用以及实例集锦
2014/06/12 PHP
php 实现进制相互转换
2016/04/07 PHP
深入浅析PHP无限极分类的案例教程
2016/05/09 PHP
总结PHP如何获取当前主机、域名、网址、路径、端口和参数等
2016/09/09 PHP
微信第三方登录(原生)demo【必看篇】
2017/05/26 PHP
Laravel 实现密码重置功能
2018/02/23 PHP
Laravel创建数据库表结构的例子
2019/10/09 PHP
犀利的js 函数集合
2009/06/11 Javascript
JavaScript中的值类型转换介绍
2014/12/31 Javascript
javascript实现根据3原色制作颜色选择器的方法
2015/07/17 Javascript
JavaScript实现AOP详解(面向切面编程,装饰者模式)
2017/12/19 Javascript
微信小程序将字符串生成二维码图片的操作方法
2018/07/17 Javascript
前端axios下载excel文件(二进制)的处理方法
2018/07/31 Javascript
小程序显示弹窗时禁止下层的内容滚动实现方法
2019/03/20 Javascript
将Vue组件库更换为按需加载的方法步骤
2020/05/06 Javascript
如何在微信小程序中使用骨架屏的步骤
2020/06/12 Javascript
vue3.0自定义指令(drectives)知识点总结
2020/12/27 Vue.js
[07:25]DOTA2-DPC中国联赛2月5日Recap集锦
2021/03/11 DOTA
Python如何实现文本转语音
2016/08/08 Python
Python基于whois模块简单识别网站域名及所有者的方法
2018/04/23 Python
Python使用add_subplot与subplot画子图操作示例
2018/06/01 Python
python基于C/S模式实现聊天室功能
2019/01/09 Python
解决python线程卡死的问题
2019/02/18 Python
Django框架序列化与反序列化操作详解
2019/11/01 Python
Python解析多帧dicom数据详解
2020/01/13 Python
tensorflow 初始化未初始化的变量实例
2020/02/06 Python
在keras中model.fit_generator()和model.fit()的区别说明
2020/06/17 Python
使用CSS3编写类似iOS中的复选框及带开关的按钮
2016/04/11 HTML / CSS
美国珠宝网上商店:Jeulia
2016/09/01 全球购物
澳大利亚运动鞋商店:Platypus Shoes
2019/09/27 全球购物
建筑工程造价专业自荐信
2014/07/08 职场文书
井冈山红色之旅感想
2014/10/07 职场文书
2014年银行客户经理工作总结
2014/11/12 职场文书
2015年专项整治工作总结
2015/04/03 职场文书
HTML基础详解(下)
2021/10/16 HTML / CSS