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基于BeautifulSoup实现抓取网页指定内容的方法
Jul 09 Python
Python自动扫雷实现方法
Jul 25 Python
Python解析excel文件存入sqlite数据库的方法
Nov 15 Python
Python中的CSV文件使用&quot;with&quot;语句的方式详解
Oct 16 Python
pycharm执行python时,填写参数的方法
Oct 29 Python
使用Py2Exe for Python3创建自己的exe程序示例
Oct 31 Python
在cmd中查看python的安装路径方法
Jul 03 Python
Python 绘制酷炫的三维图步骤详解
Jul 12 Python
python计算无向图节点度的实例代码
Nov 22 Python
python中的线程threading.Thread()使用详解
Dec 17 Python
Python DataFrame使用drop_duplicates()函数去重(保留重复值,取重复值)
Jul 20 Python
python opencv肤色检测的实现示例
Dec 21 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
无限级别菜单的实现
2006/10/09 PHP
JpGraph php柱状图使用介绍
2011/08/23 PHP
在PHP站点的页面上添加Facebook评论插件的实例教程
2016/01/08 PHP
无需数据库在线投票调查php代码
2016/07/20 PHP
Jquery 动态添加按钮实现代码
2010/05/06 Javascript
Javascript中获取出错代码所在文件及行数的代码
2010/09/23 Javascript
Jquery中给animation加更多的运作效果实例
2013/09/05 Javascript
用jquery统计子菜单的条数示例代码
2013/10/18 Javascript
JavaScript伸缩的菜单简单示例
2013/12/03 Javascript
jquery 获取dom固定元素 添加样式的简单实例
2014/02/04 Javascript
浅谈JavaScript 框架分类
2014/11/10 Javascript
AngularJS教程之MVC体系结构详解
2016/08/16 Javascript
Laravel中常见的错误与解决方法小结
2016/08/30 Javascript
AngularJS操作键值对象类似java的hashmap(填坑小结)
2016/11/12 Javascript
Vue.js展示AJAX数据简单示例讲解
2017/03/29 Javascript
JavaScript之promise_动力节点Java学院整理
2017/07/03 Javascript
Angular2 自定义validators的实现方法
2017/07/05 Javascript
详解VUE2.X过滤器的使用方法
2018/01/11 Javascript
记一次用vue做的活动页的方法步骤
2019/04/11 Javascript
nodejs实现用户登录路由功能
2019/05/22 NodeJs
python 字典(dict)遍历的四种方法性能测试报告
2014/06/25 Python
Python中输出ASCII大文字、艺术字、字符字小技巧
2015/04/28 Python
Python单元测试unittest的具体使用示例
2018/12/17 Python
python实现静态web服务器
2019/09/03 Python
Django 自定义分页器的实现代码
2019/11/24 Python
利用python实现.dcm格式图像转为.jpg格式
2020/01/13 Python
Python实现链表反转的方法分析【迭代法与递归法】
2020/02/22 Python
解决Python中报错TypeError: must be str, not bytes问题
2020/04/07 Python
Unineed中文官网:高端护肤美妆与时尚配饰,英国直邮
2020/07/23 全球购物
关于环保的建议书400字
2014/03/12 职场文书
保密工作承诺书
2014/08/29 职场文书
小区的门卫岗位职责
2014/10/01 职场文书
2014光棍节单身联谊活动策划书
2014/10/10 职场文书
2015年护理工作总结范文
2015/04/03 职场文书
python实现监听键盘
2021/04/26 Python
解决使用了nginx获取IP地址都是127.0.0.1 的问题
2021/09/25 Servers