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 相关文章推荐
Django接受前端数据的几种方法总结
Nov 04 Python
Python创建普通菜单示例【基于win32ui模块】
May 09 Python
python 爬虫 批量获取代理ip的实例代码
May 22 Python
Python实现将通信达.day文件读取为DataFrame
Dec 22 Python
Python获取航线信息并且制作成图的讲解
Jan 03 Python
python tqdm 实现滚动条不上下滚动代码(保持一行内滚动)
Feb 19 Python
python为Django项目上的每个应用程序创建不同的自定义404页面(最佳答案)
Mar 09 Python
Python Selenium截图功能实现代码
Apr 26 Python
常用的10个Python实用小技巧
Aug 10 Python
浅析Python中字符串的intern机制
Oct 03 Python
使用Python实现NBA球员数据查询小程序功能
Nov 09 Python
python如何读取和存储dict()与.json格式文件
Jun 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
10个可以简化php开发过程的MySQL工具
2010/04/11 PHP
php单元测试phpunit入门实例教程
2017/11/17 PHP
jquery写个checkbox——类似邮箱全选功能
2013/03/19 Javascript
Javascript中的for in循环和hasOwnProperty结合使用
2013/06/05 Javascript
原生javascript获取元素样式
2014/12/31 Javascript
js实现的牛顿摆效果
2015/03/31 Javascript
ECMAScript6函数默认参数
2015/06/12 Javascript
纯javascript代码实现计算器功能(三种方法)
2015/09/07 Javascript
JS获取复选框的值,并传递到后台的实现方法
2016/05/30 Javascript
支持移动端原生js轮播图
2017/02/16 Javascript
ES6学习教程之块级作用域详解
2017/10/09 Javascript
浅谈Vue.nextTick 的实现方法
2017/10/25 Javascript
js实现倒计时器自定义时间和暂停
2019/02/25 Javascript
用Node写一条配置环境的指令
2019/11/14 Javascript
Vue + element 实现多选框组并保存已选id集合的示例代码
2020/06/03 Javascript
在Python的Django框架的视图中使用Session的方法
2015/07/23 Python
python爬虫爬取淘宝商品信息(selenum+phontomjs)
2018/02/24 Python
pytorch 把MNIST数据集转换成图片和txt的方法
2018/05/20 Python
python操作excel的包(openpyxl、xlsxwriter)
2018/06/11 Python
python+webdriver自动化环境搭建步骤详解
2019/06/03 Python
django创建简单的页面响应实例教程
2019/09/06 Python
python是怎么被发明的
2020/06/15 Python
python Selenium 库的使用技巧
2020/10/16 Python
canvas粒子动画背景的实现示例
2018/09/03 HTML / CSS
季度思想汇报
2014/01/01 职场文书
爱情寄语大全
2014/04/09 职场文书
办公室主任四风问题对照检查材料思想汇报
2014/09/28 职场文书
幼儿园学前班幼儿评语
2014/12/29 职场文书
不同意离婚上诉状
2015/05/23 职场文书
音乐剧猫观后感
2015/06/04 职场文书
堂吉诃德读书笔记
2015/06/30 职场文书
python实现的web监控系统
2021/04/27 Python
教你怎么用Python生成九宫格照片
2021/05/20 Python
python 如何在list中找Topk的数值和索引
2021/05/20 Python
用Python编写简单的gRPC服务的详细过程
2021/07/04 Python
MySQL数据库之存储过程 procedure
2022/06/16 MySQL