题目描述

Leetcode 24 题主要考察的链表的反转,而 25 题是 24 的拓展版,加上对递归的考察。

对题目做一下概述:

提供一个链表,给定一个正整数 k, 每 k 个节点一组进行翻转,最后返回翻转后的新链表。

k 的值小于或等于链表的长度,如果节点总数不是 k 的整数倍,将最后一组剩余的节点保持原有顺序。

注意:

  • 算法只能使用常数的空间
  • 不能单纯的改变节点内部的值,需要进行节点交换。

举例:

Example:
Given 1->2->3->4->5.
For k = 2, you should return: 2->1->4->3->5
For k = 3, you should return: 3->2->1->4->5 Given 1->2.
For k = 2, you should return: 2->1
For k = 3, you should return: 1->2

解题思路

主要考察来了我们对链表的反转已经递归思想的熟悉度。

对链表反转时,可以借助三个指针,pre,current,next

  • pre 表示被翻转节点的前一个节点
  • current 表示正在被翻转的节点
  • next 表示正在被翻转的下一个节点

每次翻转时:

  • next 指向 current 的下一个
  • current 的 next 指向 prev
  • 同时 current 和 prev 向前一步

在每次翻转后:

  • current 表示下一个需要被翻转组中的第一个节点
  • prev 表示当前翻转后的新链表头
  • 原来的头 head 成了被翻转组中的尾节点

递归的处理

首先看到 K 个一组,想到到局部处理,并且局部处理翻转的方式是一致的,自然联想到递归。

递归的出口就是,被翻转后的新链表头或者未满足条件无需翻转的链表头。

代码实现:

# Question: Reverse Nodes in k-Group
# Given a linked list, reverse the nodes of a linked list k at a time and
# return its modified list.
#
# k is a positive integer and is less than or equal to the length of the linked
# list. If the number of nodes is not a multiple of k then left-out nodes in the
# end should remain as it is. # Example:
# Given 1->2->3->4->5.
# For k = 2, you should return: 2->1->4->3->5
# For k = 3, you should return: 3->2->1->4->5 # Note:
# Only constant extra memory is allowed.
# You may not alter the values in the list's nodes, only nodes itself
# may be changed. # Definition for singly-linked list. class ListNode:
def __init__(self, x):
self.val = x
self.next = None class Solution: def reverseKGroup(self, head: ListNode, k: int) -> ListNode: # check if head is NULL List
if head is None or head.next is None:
return head # get the number of nodes
list_length = 0
new_head = head
while new_head is not None:
list_length += 1
new_head = new_head.next # If the length of nodes is less than the number of group
if list_length < k:
return head # calculate the number of groups that can be reversed
number_of_groups = int(list_length / k) return self.swapPairs(head, k, number_of_groups) def swapPairs(self, head: ListNode, k, number_of_groups, number_of_reversed_groups=0) -> ListNode: prev = None
current = head
n = k # reverse the node due to the count of n
# After the reversal is completed,
# prev is the new head of the group that has been reversed.
# current points the head of the next group to be processed.
# head is the new end of the group that has been reversed.
while current and n > 0:
n -= 1
next = current.next
current.next = prev
prev = current
current = next # after a group of nodes is reversed, then increase 1.
number_of_reversed_groups += 1 # determine whether to reverse the next group
if current is not None and number_of_reversed_groups < number_of_groups:
head.next = self.swapPairs(
current, k, number_of_groups, number_of_reversed_groups)
else:
head.next = current
return prev def print_list_node(self, head: ListNode):
result = ''
while head is not None:
result += str(head.val) + '->'
head = head.next
print(result.rstrip('->')) if __name__ == '__main__':
l1 = ListNode(1)
l2 = ListNode(2)
l3 = ListNode(3)
l4 = ListNode(4)
l5 = ListNode(5) l1.next = l2
l2.next = l3
l3.next = l4
l4.next = l5 solution = Solution()
solution.print_list_node(l1)
reversed_l1 = solution.reverseKGroup(l1, 2)
solution.print_list_node(reversed_l1)

Leetcode 25/24 - Reverse Nodes in k-Group的更多相关文章

  1. [Leetcode] Reverse nodes in k group 每k个一组反转链表

    Given a linked list, reverse the nodes of a linked list k at a time and return its modified list. If ...

  2. Reverse Nodes In K Group,将链表每k个元素为一组进行反转---特例Swap Nodes in Pairs,成对儿反转

    问题描述:1->2->3->4,假设k=2进行反转,得到2->1->4->3:k=3进行反转,得到3->2->1->4 算法思想:基本操作就是链表 ...

  3. 【LeetCode】863. All Nodes Distance K in Binary Tree 解题报告(Python)

    [LeetCode]863. All Nodes Distance K in Binary Tree 解题报告(Python) 作者: 负雪明烛 id: fuxuemingzhu 个人博客: http ...

  4. [Leetcode][Python]24: Swap Nodes in Pairs

    # -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 24: Swap Nodes in Pairshttps://oj.leetc ...

  5. 【LeetCode】24. Swap Nodes in Pairs (3 solutions)

    Swap Nodes in Pairs Given a linked list, swap every two adjacent nodes and return its head. For exam ...

  6. LeetCode解题报告—— Reverse Nodes in k-Group && Sudoku Solver

    1. Reverse Nodes in k-Group Given a linked list, reverse the nodes of a linked list k at a time and ...

  7. LeetCode OJ:Reverse Nodes in k-Group(K个K个的分割节点)

    Given a linked list, reverse the nodes of a linked list k at a time and return its modified list. If ...

  8. LeetCode(25)Reverse Nodes in k-Group

    题目 Given a linked list, reverse the nodes of a linked list k at a time and return its modified list. ...

  9. [leetcode]算法题目 - Reverse Nodes in k-Group

    Given a linked list, reverse the nodes of a linked list k at a time and return its modified list. If ...

随机推荐

  1. 研究了3天,终于将 Shader 移植到 Cocos Creator 2.2.0 上了!

    预览 扫光特效-Fluxay2 马赛克像素特效-Mosaic 过渡效果-Transfer Shawn 花了3天时间,研究了Cocos Creator 2.2.0 的 Effect 语法,终于在1024 ...

  2. jmeter-操作mysql

    1.下载mysql驱动并放至如下目录:E:\soft\apache-jmeter-5.1.1\lib\ext 2.添加JDBC Connection Configuration(线程组-配置元件-JD ...

  3. Python之文件的使用

    文件概述 读写文件是最常见的IO操作.Python内置了读写文件的函数,用法和C是兼容的. 读写文件前,我们先必须了解一下,在磁盘上读写文件的功能都是由操作系统提供的,现代操作系统不允许普通的程序直接 ...

  4. 基于SignalR的服务端和客户端通讯处理

    SignalR是一个.NET Core/.NET Framework的实时通讯的框架,一般应用在ASP.NET上,当然也可以应用在Winform上实现服务端和客户端的消息通讯,本篇随笔主要基于Sign ...

  5. ajax跨域简单请求与复杂请求

    开发网站时经常会用到跨域资源共享(简称cors,后面使用简称)来解决跨域问题,但是在使用cors的时候,http请求会被划分为两类,简单请求和复杂请求,而这两种请求的区别主要在于是否会触发cors预检 ...

  6. (二)AS给button添加点击事件

    三种方法给Button添加点击事件 (一)通过button的id,添加继承View.OnClickListener的监听实现 <Button android:id="@+id/btn_ ...

  7. Dubbo配合SpringBoot,实现接口多个实现(group)

    SpringBoot配合Dubbo,使用@Service和@Reference,group实现接口多实现 公司项目升级,需要实现springBoot + Dubbo,并支持一个接口多个实现的情况.遇到 ...

  8. SpringBoot系列之YAML配置用法

    1.全局配置 SpringBoot的全局配置文件有两种: application.properties application.yml 配置文件的作用:修改SpringBoot自动配置的默认值,主要是 ...

  9. vue学习笔记-遗留问题记录

    Node.js是什么?对node.js的理解 官网解释:Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行时. 这是一种通过JavaScript语言开发web服务端的东 ...

  10. Spring入门介绍

    概述 下载地址:https://repo.spring.io/release/org/springframework/spring/ spring是开源的轻量级框架 spring核心的主要两部分 AO ...