Python——数据结构——链表——反转单链表中索引n~m处结点

反转单链表中索引n~m处结点

在前一篇博文中,我们实现了单链表的整体反转,今天我们来实现单链表的部分反转。

部分反转:顾名思义,只反转链表的一部分。我们需要指定反转的索引范围。

实现方法:递归,需要考虑索引是否从头开始。

1.代码如下:

#!/usr/bin/python
# -*- coding: UTF-8 -*-
"""
@author:cfl
@file:反转单向链表中索引n~m处的结点.py
@time:2021/12/14
@software:PyCharm
"""
from slinklist import SlinkList


# 反转链表第n-m位
def passrev(sll, n, m):
    p1 = sll.phead
    ii = 0
    if n > 0:

        while ii < (n - 1):
            p1 = p1.next
            ii += 1

        # 要反转的结点的起始节点
        startNode = p1.next

    else:
        startNode = sll.phead
        ii -= 1

    def reversal(node, ii):
        ii += 1
        if ii < m:
            nextNode = node.next
            reversal(nextNode, ii)
            nextNode.next = node
        else:
            startNode.next = node.next
            if n > 0:
                p1.next = node
            else:
                sll.phead = node

    reversal(startNode, ii)


def main():

    sll=SlinkList()
    for i in range(10):
        sll.appendtail(i)
    print(sll.display())

    # 反转链表
    passrev(sll,0,7)
    print(sll.display())


if __name__ == '__main__':
    main()

from slinklist import SlinkList 是单链表的定义类,可以参见我的另一篇博文:单链表的Python实现

2.测试结果

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

同学陈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值