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|反转链表问题解决方法的主要内容,如果未能解决你的问题,请参考以下文章

反转链表(两种Python解法)

Leetcode练习(Python):链表类:第206题:反转链表:反转一个单链表。

206. 反转链表

反转链表算法题

一道简单的局部链表反转的问题,具体解决时的麻烦的分类

LeetCode206. 反转链表