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中datetime常用时间处理方法
Jun 15 Python
python用10行代码实现对黄色图片的检测功能
Aug 10 Python
python开发之tkinter实现图形随鼠标移动的方法
Nov 11 Python
python向已存在的excel中新增表,不覆盖原数据的实例
May 02 Python
Pycharm 创建 Django admin 用户名和密码的实例
May 30 Python
Python中的取模运算方法
Nov 10 Python
Python字典的核心底层原理讲解
Jan 24 Python
简单了解Java Netty Reactor三种线程模型
Apr 26 Python
Python检测端口IP字符串是否合法
Jun 05 Python
python反爬虫方法的优缺点分析
Nov 25 Python
使用Pytorch训练two-head网络的操作
May 28 Python
Python中的socket网络模块介绍
Jul 23 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+DBM的同学录程序(3)
2006/10/09 PHP
PHP 网络开发详解之远程文件包含漏洞
2010/04/25 PHP
PHP仿博客园 个人博客(1) 数据库与界面设计
2013/07/05 PHP
浅析ThinkPHP中的pathinfo模式和URL重写
2014/01/06 PHP
js 判断浏览器类型 去全角、半角空格 自动关闭当前窗口
2009/04/10 Javascript
jQuery插件原来如此简单 jQuery插件的机制及实战
2012/02/07 Javascript
jQuery去掉字符串起始和结尾的空格(多种方法实现)
2013/04/01 Javascript
对frameset、frame、iframe的js操作示例代码
2013/08/16 Javascript
jQuery的显示和隐藏方法与css隐藏的样式对比
2013/10/18 Javascript
js快速排序的实现代码
2013/12/08 Javascript
jquery获取对象的方法足以应付常见的各种类型的对象
2014/05/14 Javascript
JavaScript中判断变量是数组、函数或是对象类型的方法
2015/02/25 Javascript
JavaScript将当前时间转换成UTC标准时间的方法
2015/04/06 Javascript
JQuery实现图片轮播效果
2015/09/15 Javascript
详谈javascript异步编程
2016/02/21 Javascript
JS简单设置下拉选择框默认值的方法
2016/08/20 Javascript
JavaScript 异步调用
2017/10/25 Javascript
小程序实现发表评论功能
2018/07/06 Javascript
如何从零开始手写Koa2框架
2019/03/22 Javascript
jQuery内容选择器与表单选择器实例分析
2019/06/28 jQuery
node.js事件轮询机制原理知识点
2019/12/22 Javascript
一篇文章带你搞懂Vue虚拟Dom与diff算法
2020/08/25 Javascript
Vue中的nextTick作用和几个简单的使用场景
2021/01/25 Vue.js
[30:00]完美世界DOTA2联赛PWL S2 Rebirth vs LBZS 第二场 11.28
2020/12/01 DOTA
浅析Python的Django框架中的Memcached
2015/07/23 Python
Python实现仿射密码的思路详解
2020/04/23 Python
python3用PyPDF2解析pdf文件,用正则匹配数据方式
2020/05/12 Python
Pycharm安装并配置jupyter notebook的实现
2020/05/18 Python
python 30行代码实现蚂蚁森林自动偷能量
2021/02/08 Python
amazeui时间组件的实现示例
2020/08/18 HTML / CSS
测绘工程个人的自我评价
2013/11/23 职场文书
义卖募捐活动总结
2015/05/09 职场文书
班主任经验交流心得体会
2015/11/02 职场文书
关于元旦的广播稿2016
2015/12/17 职场文书
科级干部培训心得体会
2016/01/06 职场文书
python对文档中元素删除,替换操作
2022/04/02 Python