python链表的反转方式是什么


本篇内容介绍了“python链表的反转方式是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。输入:head = [1,2,3,4,5]输出:[5,4,3,2,1]输入:head = [1,2]输出:[2,1]示例 3:输入:head = []输出:[]给定一个单链表的头结点pHead(该头节点是有值的,比如在下图,它的val是1),长度为n,反转该链表后,返回新链表的表头。要求:空间复杂度O(1)O(1),时间复杂度O(n)O(n)。输入:{1,2,3}返回值:{3,2,1}先来看最基本的反转链表代码:抓住几个关键点:cur:原链表的头节点,在反转结束时,cur指向pre的下一个节点pre:原链表的尾节点,也就是反转后链表的头节点。最终返回的是pre。while cur:表示反转循环的条件,这里是判断cur是否为空。也可以根据题目的条件改成其他循环条件反转链表的尾节点,这里的尾节点是None,后面会提到显式指定。对于反转链表的问题,抓住原链表的头节点、原链表的尾节点、反转循环条件、反转链表的尾节点这几个主要角色,基本没什么问题。接下来,举两个例子:链表内指定区间反转链表中的节点每k个一组翻转将一个节点数为 size 链表 m位置到n 位置之间的区间反转,要求时间复杂度 O(n),空间复杂度O(1)。要求:时间复杂度O(n),空间复杂度O(n)进阶:时间复杂度O(n),空间复杂度O(1)输入:{1,2,3,4,5},2,4返回值:{1,4,3,2,5}套用公式这道题目和baseline的区别是,是将对整个链表的反转改成链表 m位置到n 位置之间的区间反转,来套一下公式:原链表的头节点:cur:从head出发,再走m-1步,到达cur原链表的尾节点:pre:cur前面的节点反转循环条件:for i in range(n,m)反转链表的尾节点:需要保存下从head出发,再走m-1步,到达cur时,此时pre的位置 prePos。prePos.next是反转链表的尾节点和前面的比免费云主机域名,需要额外注意下:需要保存下从head出发,再走m-1步,到达cur时,此时pre的位置 prePos。在反转循环结束后,再进行穿针引线由于不是对整个链表进行反转,最好新建虚拟头节点dummpyNode,dummpyNode.next指向整个链表代码实现先看下套公式部分的代码:穿针引线部分代码:完整代码:将给出的链表中的节点每 k个一组翻转,返回翻转后的链表如果链表中的节点数不是 k 的倍数,将最后剩下的节点保持原样你不能更改节点中的值,只能更改节点本身。要求空间复杂度 O(1),时间复杂度O(n)输入:{1,2,3,4,5},2返回值:{2,1,4,3,5}套用公式这道题目和baseline的区别是,是将对整个链表的反转改成每k个一组反转,如果节点数不是k的倍数,剩下的节点保持原样。先分段来看,假设面对位置1-位置k的链表:原链表的头节点:cur:从head出发,再走k-1步,到达cur原链表的尾节点:pre:cur前面的节点反转循环条件:for i in range(1,k)反转链表的尾节点:先定义tail=head,等反转完后tail.next就是反转链表的尾节点先看下套公式部分的代码:这样,我们就得到了1位置1-位置k的反转链表。此时:pre:指向反转链表的头节点cur:位置k+1的节点,下一段链表的头节点tail:反转链表的尾节点那么,得到位置k+1-位置2k的反转链表,就可以用递归的思路,用tail.next=reverse(cur,k)需要注意:如果链表中的节点数不是 k 的倍数,将最后剩下的节点保持原样代码实现完整代码:好了,抓住几个关键点:cur:原链表的头节点,在反转结束时,cur指向pre的下一个节点pre:原链表的尾节点,也就是反转后链表的头节点。最终返回的是pre。while cur:表示反转循环的条件,这里是判断cur是否为空。也可以根据题目的条件改成其他循环条件反转链表的尾节点,这里的尾节点是None,后面会提到显式指定。“python链表的反转方式是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注百云主机网站,小编将为大家输出更多高质量的实用文章!

相关推荐: android怎么实现在图标上显示数字

这篇文章主要介绍了android怎么实现在图标上显示数字的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇android怎么实现在图标上显示免费云主机域名数字文章都会有所收获,下面我们一起来看看吧。效果图:动态显示当天的号数。主要代码…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

Like (0)
Donate 微信扫一扫 微信扫一扫
Previous 06/03 09:56
Next 06/03 09:57

相关推荐