Python|反转链表问题解决方法
Posted 算法与编程之美
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python|反转链表问题解决方法相关的知识,希望对你有一定的参考价值。
本文首发于微信公众号:"算法与编程之美",欢迎关注,及时了解更多此系列文章。
问题描述
给你单链表的头指针 head 和两个整数 left 和 right ,其中 left <= right 。请你反转从位置 left 到位置 right 的链表节点,返回 反转后的链表 。
示例 1:
输入:head = [1,2,3,4,5], left = 2, right = 4
输出:[1,4,3,2,5]
示例 2:
输入:head = [5], left = 1, right = 1
输出:[5]
解决方案
首先创建一个空节点指向head,两个指针同时遍历,并用tmp记录当前节点的下一个节点用两个指针遍历整个链表,首先找到left的位置,当当前节点小于target时继续让当前节点指向下一个节点,直到找到left的位置,找到left的位置时便可使用头插法将left后面的元素直到right插入到left前面
以示例1为例子:
1.初始状态
2.第一轮变换
3.第三轮变换
代码清单
p1=ListNode(0)#创建空节点 x=p1 p1.next=head p=head#定义当前节点 i=1#用于判断与left的关系 while i <left:#当没有找到left时,继续指向下一个节点 p1=p1.next p=p.next i=i+1 while i < right:#找到left时用头插法进行插入 tmp=p.next#记录当前节点的下一个节点 p.next=tmp.next tmp.next=p1.next p1.next=tmp i=i+1 print( x.next)
|
结语
本篇主要解决了链表反转的问题,其中核心思想为头插法,利用头插法可以帮助我们很快的解决链表反转的问题,同时头插法作用很大,可以帮助我们解决很多的有关链表的问题,在我们以后遇到关于链表问题时都可以考虑是否能用到头插法,所以对于头插法我们需要取熟练的掌握并且运用,对我们的编程能力会有很大的提升
实习编辑:衡辉
作者:邓斯丹、陈文杰、李俭
稿件来源:深度学习与文旅应用实验室(DLETA)
以上是关于Python|反转链表问题解决方法的主要内容,如果未能解决你的问题,请参考以下文章