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 list语法学习(带例子)
Nov 01 Python
Python实现上下班抢个顺风单脚本
Feb 07 Python
python logging重复记录日志问题的解决方法
Jul 12 Python
浅谈pytorch和Numpy的区别以及相互转换方法
Jul 26 Python
tensorflow实现逻辑回归模型
Sep 08 Python
python基于递归解决背包问题详解
Jul 03 Python
Django打印出在数据库中执行的语句问题
Jul 25 Python
Python3实现zip分卷压缩过程解析
Oct 09 Python
Python爬虫:Request Payload和Form Data的简单区别说明
Apr 30 Python
Django xadmin安装及使用详解
Oct 26 Python
python tqdm用法及实例详解
Jun 16 Python
7个关于Python的经典基础案例
Nov 07 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中的字符串函数
2006/11/24 PHP
浅析PHP原理之变量(Variables inside PHP)
2013/08/09 PHP
thinkPHP模板算术运算相关函数用法分析
2016/07/12 PHP
PHP中trait使用方法详细介绍
2017/05/21 PHP
PHP实现微信小程序人脸识别刷脸登录功能
2018/05/24 PHP
php操作redis数据库常见方法实例总结
2020/02/20 PHP
SlideView 图片滑动(扩展/收缩)展示效果
2010/08/01 Javascript
子窗口、父窗口和Silverlight之间的相互调用
2010/08/16 Javascript
从数据库读取数据后将其输出成html标签的三种方法
2014/10/13 Javascript
ExpressJS入门实例
2015/01/14 Javascript
JS+CSS实现精美的二级导航效果代码
2015/09/17 Javascript
12个非常实用的JavaScript小技巧【推荐】
2016/05/18 Javascript
JavaScript正则表达式exec/g实现多次循环用法示例
2017/01/17 Javascript
vue 指定组件缓存实例详解
2018/04/01 Javascript
通过 JS 判断页面是否有滚动条的实现方法
2018/04/05 Javascript
自定义Vue中的v-module双向绑定的实现
2019/04/17 Javascript
微信小程序上传文件到阿里OSS教程
2019/05/20 Javascript
详解vuex的简单todolist例子
2019/07/14 Javascript
Vue学习之常用指令实例详解
2020/01/06 Javascript
在项目vue中使用echarts的操作步骤
2020/09/07 Javascript
[44:43]完美世界DOTA2联赛决赛日 FTD vs GXR 第一场 11.08
2020/11/11 DOTA
[07:01]DOTA2-DPC中国联赛正赛 Aster vs Magma 3月5日 赛后选手采访
2021/03/11 DOTA
Python实现字典去除重复的方法示例
2017/07/31 Python
python利用ffmpeg进行录制屏幕的方法
2019/01/10 Python
Python全栈之列表数据类型详解
2019/10/01 Python
Python Django框架url反向解析实现动态生成对应的url链接示例
2019/10/18 Python
Python MySQLdb 执行sql语句时的参数传递方式
2020/03/04 Python
基于python实现操作redis及消息队列
2020/08/27 Python
Python字典实现伪切片功能
2020/10/28 Python
运动会广播稿500字
2014/01/28 职场文书
翻译学院毕业生自荐书
2014/02/02 职场文书
渔夫的故事教学反思
2014/02/14 职场文书
个人借款担保书
2014/04/02 职场文书
单位委托书格式范本
2014/09/29 职场文书
省委召开党的群众路线教育实践活动总结大会报告
2014/10/21 职场文书
2016年最美孝心少年事迹材料
2016/02/26 职场文书