返回顶部
首页 > 资讯 > 后端开发 > Python >python递归实现链表快速倒转
  • 322
分享到

python递归实现链表快速倒转

2024-04-02 19:04:59 322人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

本文实例为大家分享了python递归实现链表快速倒转的具体代码,供大家参考,具体内容如下 案例:实现如下链表进行倒转 源代码: ''' node 用于表示队列中的节点;它包含两个域

本文实例为大家分享了python递归实现链表快速倒转的具体代码,供大家参考,具体内容如下

案例:实现如下链表进行倒转

源代码:

'''
node 用于表示队列中的节点;它包含两个域。
val 表示节点的值。
next指向下一个节点
'''
#定义链表的数据结构
class Node:
    def __init__(self,val):
        self.next = None
        self.val  = val

class ListUtility:#生成一个用来操作的链表
    def __init__(self):
        self.head = None
        self.tail = None
        pass
    def createList(self,nodeNum):
        if nodeNum <= 0:
            return None
        head = None
        val = 0
        node = None
        while nodeNum > 0:
    #如果head指针为空,代码先构造队列头部,如果不为空,代码构造节点对象,然后用上一个节点的next指针指向当前节点,从而将多个节点串联成队列。
            if head is None:
                head = Node(val)
                node = head
            else:
                node.next = Node(val)
                node = node.next
                self.tail = node
            val += 1
            nodeNum -= 1
        
        self.head = head
        return head
    
    def printList(self,head):
        
        while head is not None:
            print("{0}->".fORMat(head.val),end = " ")
            head = head.next
        print("null")
                
class ListReverse:
    def __init__(self, head):
        self.listHead = head
        self.newHead = None
    def recursiveReverse(self, node):
        #如果队列为空或者只有一个节点,那么队列已经倒转完成
        if node is None or node.next is None:
            self.newHead = node
            return node
        '''
        如果队列包含多个节点,那么通过递归调用的方式,先把当前节点之后所有节点实现倒转,
        然后再把当前节点之后节点的next指针指向自己从而完成整个列表所有节点的导致
        '''
        head = self.recursiveReverse(node.next)
        head.next = node
        node.next = None
        return node
    def getReverseList(self):
        '''
        listHead是原队列头节点,执行recursiveReverse后newHead指向新列表的头结点,它
        对应的其实是原列表的尾节点,而head指向新列表的尾节点
        '''
        self.recursiveReverse(self.listHead)
        return self.newHead
 utility = ListUtility()
head = utility.createList(10)
utility.printList(head)
#执行倒转算法,然后再次打印队列,前后对比看看导致是否成功
reverse = ListReverse(head)
utility.printList(reverse.getReverseList())   

运行结果:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: python递归实现链表快速倒转

本文链接: https://lsjlt.com/news/117586.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • python递归实现链表快速倒转
    本文实例为大家分享了python递归实现链表快速倒转的具体代码,供大家参考,具体内容如下 案例:实现如下链表进行倒转 源代码: ''' Node 用于表示队列中的节点;它包含两个域...
    99+
    2024-04-02
  • 怎么用python递归实现链表快速倒转
    这篇文章主要介绍“怎么用python递归实现链表快速倒转”,在日常操作中,相信很多人在怎么用python递归实现链表快速倒转问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用python递归实现链表快速倒转...
    99+
    2023-06-30
  • python递归&迭代方法实现链表反转
    定义链表node结构: class ListNode:       def __init__(self,data):         self.data = data        ...
    99+
    2024-04-02
  • 快速排序详解(递归实现与非递归实现)
    目录 一、快速排序的基本思想 二、将序列划分成左右区间的常见方法 2.1hoare版本(动图+解释+代码实现) 2.2挖坑法 2.3前后指针法 三、快速排序的初步实现 四、快速排序的优化实现 4.1快排的特殊情况 4.2对区间划分代码的...
    99+
    2023-10-24
    排序算法 算法 数据结构 c++
  • 聊聊golang怎么用递归实现反转链表
    在golang中,反转链表可以使用递归来实现。在递归函数中,我们首先需要将当前节点的下一个节点作为参数传入递归函数,然后让当前节点指向下一个节点的下一个节点。最后返回递归函数的返回值,即新的头节点。以下是使用递归实现反转链表的golang代...
    99+
    2023-05-14
  • python中如何用递归与迭代方法实现链表反转
    这篇文章主要讲解了“python中如何用递归与迭代方法实现链表反转”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“python中如何用递归与迭代方法实现链表反转”吧!定义链表node结构:cl...
    99+
    2023-06-29
  • 如何使用PHP递归实现链表的反转操作
    链表是一种非常常见的数据结构,是由一系列节点组成的集合,每个节点包含一个数据项和指向下一个节点的指针。链表可以用来实现栈、队列、哈希表等数据结构,并且在算法题中也常常遇到。在许多算法问题中,需要对链表进行反转操作。反转链表的基本思路是将链表...
    99+
    2023-05-14
    php
  • 怎么使用PHP递归实现链表的反转操作
    本文小编为大家详细介绍“怎么使用PHP递归实现链表的反转操作”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么使用PHP递归实现链表的反转操作”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。实现方法在递归反转链表...
    99+
    2023-07-05
  • java实现单链表倒转的方法
    java中有关单链表反转的方法有很多种,这里记录一种并附上详细步骤: 代码如下 public class Solution {     public ListNode revers...
    99+
    2024-04-02
  • 怎么理解Java递归单链表反转
    这篇文章主要讲解了“怎么理解Java递归单链表反转”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么理解Java递归单链表反转”吧!首先,咱们要先明确,什么...
    99+
    2024-04-02
  • C++归并法+快速排序实现链表排序的方法
    本文主要介绍了C++归并法+快速排序实现链表排序的方法,分享给大家,具体如下: 我们可以试用归并排序解决: 对链表归并排序的过程如下。 找到链表的中点,以中点为分界,将链表拆分成...
    99+
    2024-04-02
  • PHP怎么实现快速排序的非递归算法
    介绍快速排序是一种高效的排序算法,它通过不断地将一个数组分成两个子数组来实现排序。在快速排序算法中,一个基准值(pivot)被选出并所有小于基准值的元素放在其左侧,而所有大于基准值的元素放在其右侧。然后,这个过程被递归地应用在左右两侧的子数...
    99+
    2023-05-14
  • C++实现LeetCode(206.倒置链表)
    [LeetCode] 206.Reverse Linked List 倒置链表 Reverse a singly linked list. Example: Input: 1-&g...
    99+
    2024-04-02
  • python怎么实现递归
    这篇文章将为大家详细讲解有关python怎么实现递归,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。最简单的递归的实例  # -*- coding:ut...
    99+
    2024-04-02
  • python快速排序怎么实现元素递增
    本篇内容介绍了“python快速排序怎么实现元素递增”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!概念快速排序法又称分割交换法,是冒泡排序法...
    99+
    2023-06-30
  • C++实现LeetCode(92.倒置链表之二)
    [LeetCode] 92. Reverse Linked List II 倒置链表之二 Reverse a linked list from position m...
    99+
    2024-04-02
  • python如何实现递归求和
    这篇文章主要介绍python如何实现递归求和,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!递归求和python的数据类型有哪些python的数据类型:1. 数字类型,包括int(整型...
    99+
    2024-04-02
  • go实现反转链表
    反转链表首先讨论特殊节点 如果节点在首位,则反转之后,首位节点的next值为nil。 func reverse(head *ListNode) *ListNode ...
    99+
    2022-06-07
    GO 反转 链表
  • java实现链表反转
    本文为大家分享了java实现链表反转的具体代码,供大家参考,具体内容如下 算法题:实现链表的反转 提供了2种方法,迭代法、递归法。 (为了方便输出可视化,在自定义的ListNode中...
    99+
    2024-04-02
  • C++实现旋转链表
    这篇文章主要介绍“C++实现旋转链表”,在日常操作中,相信很多人在C++实现旋转链表问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++实现旋转链表”的疑惑有所帮助!接下来,请跟着小编一起来学习吧![Leet...
    99+
    2023-06-20
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作