python单向循环链表原理与实现方法示例


Posted in Python onDecember 03, 2019

本文实例讲述了python单向循环链表原理与实现方法。分享给大家供大家参考,具体如下:

单向循环链表

单链表的一个变形是单向循环链表,链表中最后一个节点的next域不再为None,而是指向链表的头节点。

python单向循环链表原理与实现方法示例

操作

  • is_empty() 判断链表是否为空
  • length() 返回链表的长度
  • travel() 遍历
  • add(item) 在头部添加一个节点
  • append(item) 在尾部添加一个节点
  • insert(pos, item) 在指定位置pos添加节点
  • remove(item) 删除一个节点
  • search(item) 查找节点是否存在

实现

# -*- coding:utf-8 -*-
#! python3
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
    while cur.next != self.__head:
      if cur.item == item:
        # 先判断此结点是否是头节点
        if cur == self.__head:
          # 头节点的情况
          # 找尾节点
          rear = self.__head
          while rear.next != self.__head:
            rear = rear.next
          self.__head = cur.next
          rear.next = self.__head
        else:
          # 中间节点
          pre.next = cur.next
        return
      else:
        pre = cur
        cur = cur.next
    # 退出循环,cur指向尾节点
    if cur.item == item:
      if cur == self.__head:
        # 链表只有一个节点
        self.__head = None
      else:
        # pre.next = cur.next
        pre.next = self.__head
  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()

运行结果:

length: 6
6
2
1
4
3
5

True
False
length: 5
6
2
4
3
5

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
python中使用urllib2伪造HTTP报头的2个方法
Jul 07 Python
Python读取ini文件、操作mysql、发送邮件实例
Jan 01 Python
浅述python2与python3的简单区别
Sep 19 Python
win10系统下Anaconda3安装配置方法图文教程
Sep 19 Python
解决python 无法加载downsample模型的问题
Oct 25 Python
Python实现连接MySql数据库及增删改查操作详解
Apr 16 Python
python分数表示方式和写法
Jun 26 Python
Django如何使用第三方服务发送电子邮件
Aug 14 Python
jupyter notebook读取/导出文件/图片实例
Apr 16 Python
在django中form的label和verbose name的区别说明
May 20 Python
Python字符串格式化常用手段及注意事项
Jun 17 Python
OpenCV图片漫画效果的实现示例
Aug 18 Python
使用 Python 清理收藏夹里已失效的网站
Dec 03 #Python
Python常用模块os.path之文件及路径操作方法
Dec 03 #Python
Python中顺序表原理与实现方法详解
Dec 03 #Python
python双向链表原理与实现方法详解
Dec 03 #Python
Python读取实时数据流示例
Dec 02 #Python
简单了解python元组tuple相关原理
Dec 02 #Python
python实现智能语音天气预报
Dec 02 #Python
You might like
php内嵌函数用法实例
2015/03/20 PHP
php编程实现简单的网页版计算器功能示例
2017/04/26 PHP
PHP实现的简单sha1加密功能示例
2017/08/27 PHP
php微信开发之关注事件
2018/06/14 PHP
解决laravel5中auth用户登录其他页面获取不到登录信息的问题
2019/10/08 PHP
Javascript 面向对象 重载
2010/05/13 Javascript
JQuery触发事件例如click
2013/09/11 Javascript
Document.location.href和.replace的区别示例介绍
2014/03/04 Javascript
Javascript前端UI框架Kit使用指南之kitjs事件管理
2014/11/28 Javascript
jQuery学习笔记之2个小技巧
2015/01/19 Javascript
javascript 获取浏览器版本
2015/01/21 Javascript
JS+CSS实现可以凹陷显示选中单元格的方法
2015/03/02 Javascript
jQuery实现锚点scoll效果实例分析
2015/03/10 Javascript
JQuery显示隐藏DIV的方法及代码实例
2015/04/16 Javascript
js省市区级联查询(插件版&amp;无插件版)
2017/03/21 Javascript
React-Native 组件之 Modal的使用详解
2017/08/08 Javascript
详解通过源码解析Node.js中cluster模块的主要功能实现
2018/05/16 Javascript
Vue使用watch监听一个对象中的属性的实现方法
2019/05/10 Javascript
javascript实现切割轮播效果
2019/11/28 Javascript
JavaScript或jQuery 获取option value值方法解析
2020/05/12 jQuery
[08:53]DOTA2每周TOP10 精彩击杀集锦vol.9
2014/06/26 DOTA
使用Python获取CPU、内存和硬盘等windowns系统信息的2个例子
2014/04/15 Python
举例讲解Python中的死锁、可重入锁和互斥锁
2015/11/05 Python
详解python分布式进程
2018/10/08 Python
Python数据可视化之画图
2019/01/15 Python
python实现的自动发送消息功能详解
2019/08/15 Python
python中sort sorted reverse reversed函数的区别说明
2020/05/11 Python
使用opencv识别图像红色区域,并输出红色区域中心点坐标
2020/06/02 Python
python如何进行矩阵运算
2020/06/05 Python
Python3爬虫mitmproxy的安装步骤
2020/07/29 Python
Python selenium环境搭建实现过程解析
2020/09/08 Python
H5仿微信界面教程(一)
2017/07/05 HTML / CSS
西班牙英格列斯百货英国官网:El Corte Inglés英国
2017/10/30 全球购物
中药学专业求职信
2014/05/31 职场文书
硕士毕业论文导师评语
2014/12/31 职场文书
Python多个MP4合成视频的实现方法
2021/07/16 Python