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转换HTML到Text纯文本的方法
Jan 15 Python
深入理解Python中各种方法的运作原理
Jun 15 Python
详解Python的Django框架中的模版继承
Jul 16 Python
Python MySQLdb 使用utf-8 编码插入中文数据问题
Mar 13 Python
一篇文章读懂Python赋值与拷贝
Apr 19 Python
基于OpenCV python3实现证件照换背景的方法
Mar 22 Python
Django结合ajax进行页面实时更新的例子
Aug 12 Python
对django layer弹窗组件的使用详解
Aug 31 Python
Python网页解析器使用实例详解
May 30 Python
详细分析Python可变对象和不可变对象
Jul 09 Python
Pytorch 图像变换函数集合小结
Feb 01 Python
Sentry的安装、配置、使用教程(Sentry日志手机系统)
Jul 23 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基于base64解码图片与加密图片还原实例
2014/11/03 PHP
详解PHP对象的串行化与反串行化
2016/01/24 PHP
PHP safe_mode开启对于PHP系统函数有什么影响
2020/11/10 PHP
js 日期转换成中文格式的函数
2009/07/07 Javascript
JQuery筛选器全系列介绍
2013/08/27 Javascript
document.documentElement和document.body区别介绍
2013/09/16 Javascript
ext前台接收action传过来的json数据示例
2014/06/17 Javascript
从数据库读取数据后将其输出成html标签的三种方法
2014/10/13 Javascript
jQuery中ajax的post()方法用法实例
2014/12/26 Javascript
Javascript获取表单名称(name)的方法
2015/04/02 Javascript
解决WordPress使用CDN后博文无法评论的错误
2015/12/15 Javascript
微信小程序 location API实例详解
2016/10/02 Javascript
jQuery Ajax File Upload实例源码
2016/12/12 Javascript
vue事件修饰符和按键修饰符用法总结
2017/07/25 Javascript
详解JS构造函数中this和return
2017/09/16 Javascript
nodejs 图片预览和上传的示例代码
2017/09/30 NodeJs
Angular实现点击按钮后在上方显示输入内容的方法
2017/12/27 Javascript
详解如何在项目中使用jest测试react native组件
2018/02/09 Javascript
jQuery实现的淡入淡出图片轮播效果示例
2018/08/29 jQuery
关于React动态加载路由处理的相关问题
2019/01/07 Javascript
ES6 Iterator接口和for...of循环用法分析
2019/07/31 Javascript
[03:54]Ehome出征西雅图 回顾2016国际邀请赛晋级之路
2016/08/02 DOTA
50行代码实现贪吃蛇(具体思路及代码)
2013/04/27 Python
Python 文本文件内容批量抽取实例
2018/12/10 Python
django框架F&amp;Q 聚合与分组操作示例
2019/12/12 Python
采用专利算法搜索最廉价的机票:CheapAir
2016/09/10 全球购物
Links of London官方网站:英国标志性的珠宝品牌
2017/04/09 全球购物
Java程序开发中如何应用线程
2016/03/03 面试题
造价工程师个人求职信
2013/09/21 职场文书
学习十八大报告感言
2014/02/04 职场文书
机关党员进社区活动总结
2014/07/05 职场文书
放飞梦想演讲稿800字
2014/08/26 职场文书
七年级地理教学计划
2015/01/22 职场文书
mysql连接查询中and与where的区别浅析
2021/07/01 MySQL
redis复制有可能碰到的问题汇总
2022/04/03 Redis
详解OpenCV曝光融合
2022/04/29 Python