首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

逆序打印不可变链表递归

题目 给您一个不可变的链表使用下列接口逆序打印每个节点的值: ImmutableListNode: 描述不可变链表的接口,链表的头节点已给出。...您需要使用以下函数来访问此链表(您 不能 直接访问 ImmutableListNode): ImmutableListNode.printValue():打印当前节点的值。...输入只用来内部初始化链表。您不可以通过修改链表解决问题。 也就是说,您只能通过上述 API 来操作链表。 进阶: 您是否可以: 使用常数级空间复杂度解决问题?...使用线性级时间复杂度和低于线性级空间复杂度解决问题?...输入:head = [0,-4,-1,3,-5] 输出:[-5,3,-1,-4,0] 示例 3: 输入:head = [-2,0,6,4,4,-6] 输出:[-6,4,4,6,0,-2] 提示: 链表的长度在

67130
您找到你想要的搜索结果了吗?
是的
没有找到

递归:反转链表

★LeetCode206 --- 反转链表【简单题】 题目描述 ” [nh1xo1l3sg.png] 题目描述 1、解题思路 题目要求我们对一个链表中的元素进行对应的反转,并且按照最后的进阶提示,尝试一下递归和迭代两种方法来完成...最终,我们返回最后一个节点,就是新链表的头结点。由此,我们就使用迭代法完成了整个链表的反转。...递归法: 我们最终需要返回的是链表的最后一个节点,所以,我们在递归过程中,需要找到最后一个节点,然后将其逐层向上抛出。...所以,我们可以去寻找链表中第m的元素的位置,然后将第m个元素当做头结点,输入到上一道题目的代码中。在寻找过程中,我们依旧使用递归的方法去探寻,每一次传入的参数将是(head,m-1,n-1)。...此时,反转过程中,我们使用到的结束条件就不再是head == null,而是n==1。由此,我们就完成了对上一道题目的改造。

85030

从尾到头打印链表

题目描述 从尾到头反过来打印出每个结点的值。 解题思路 1. 使用递归 要逆序打印链表 1->2->3(3,2,1),可以先逆序打印链表 2->3(3,2),最后再打印第一个节点 1。...而链表 2->3 可以看成一个新的链表,要逆序打印链表可以继续使用求解函数,也就是在求解函数中调用自己,这就是递归函数。...使用头插法 头插法顾名思义是将节点插入到头部:在遍历原始链表时,将当前节点插入新链表的头部,使其成为第一个节点。...不要将头结点与第一个节点混起来,第一个节点是链表中第一个真正存储值的节点。...使用栈 栈具有后进先出的特点,在遍历链表时将值按顺序放入栈中,最后出栈的顺序即为逆序。

42220

链表反转(递归和非递归方式)的正确姿势

,首先一直迭代到链尾也就是递归基判断的准则,然后再逐层返回处理到开头。...总结来说,链表翻转操作的顺序对于迭代来说是从链头往链尾,而对于递归是从链尾往链头。 下面我会用详细的图文来剖析其中实现的细节。...1、非递归(迭代)方式 迭代的方式是从链头开始处理,如下图给定一个存放5个数的链表。...首先对于链表设置两个指针: 然后依次将旧链表上每一项添加在新链表的后面,然后新链表的头指针NewH移向新的链表头,如下图所示。...最后一步: 2、递归方式 我们再来看看递归实现链表翻转的实现,前面非递归方式是从前面数1开始往后依次处理,而递归方式则恰恰相反,它先循环找到最后面指向的数5,然后从5开始处理依次翻转整个链表

1.2K20

leetcode:从头到尾打印链表

题目:描述输入一个链表的头节点,按链表从尾到头的顺序返回每个节点的值(用数组返回)。...如输入{1,2,3}的链表如下图:返回一个数组为[3,2,1]0 <= 链表长度 <= 10000示例1输入:{1,2,3}复制返回值:[3,2,1]复制示例2输入:{67,0,24,58}复制返回值:...[58,24,0,67]思路一:遍历链表的每个节点,存储在list中反转list# class ListNode:# def __init__(self, x):# self.val...链表与在内存中排列整齐的数组不同,它们像一堆散兵游勇,散布于内存中,只要哪里有空隙就往哪里钻,链表高效地运用了内存空间。虽然它们看起来杂乱无章,但其实它们井然有序,暗号让它们紧紧相连。...链表的第一个和最后一个节点最重要和最特殊,最后一个节点则意味着后面没有数据了,所以它指向None,第一个节点的内存地址需要一个地方来保存,所以设立一个head属性对第一个节点应用。

21500

算法-从尾到头打印链表

题目: 输入一个链表,要求从尾到头打印链表链表结点定义如下: struct ListNode { int value; ListNode *next; }; 解题思路: 要求很好理解...打印的结果是:6 5 4 3 2 1 1.相信大多数人看到这个要求后的第一反应是反转链表,再从头打印,但是这样一来,原始数据就改变了。...4.既然想到了是一种“先遍历后打印,后遍历先打印”的操作,那么可不可以不借助栈来实现这个方法——递归。...递归的思想在合并两个排序的链表题目中就使用过,只不过在该题目中我们返回的是最后一次递归的结果,而在本文的题目我们需要打印每一次递归的返回值。...关于思路3和4都是可以的,具体使用哪一个可以根据实际情况来决定,如果链表很长,那么递归调用的层数就会很深,可能导致函数调用栈溢出,用思路3的鲁棒性会更好一些。

54890

【日拱一卒】链表——链表反转(递归解法)

前言 上篇我们主要介绍链表反转的原地反转解法。 除此以外,是否还有其他解法? 当然,今天就来看看链表反转的递归解法。...递归 递归,字面意思,有”递“也有”归“ 拿我们经常听到的斐波那契数列来说,公式如下 f(n) = f(n-1) + f(n-2); f(1) = 1, f(2) = 1 现在比如求解f(5)的值,按照公式...递归反转链表 先上代码 func reverse(head *ListNode) *ListNode { if head == nil || head.Next == nil { return head...既然这里用到了递归的思想,那么这里 newHead := reverse(head.Next) head.Next即为4,我们拿到的newHead此时就是一个已经完成反转的链表了,这是目前还差5这个节点...你数组、链表、栈、队列、堆、排序、查找都整不明白,你学什么算法 小王:我只学链表反转递归解法 老王:。。。

53610
领券