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

If the number of nodes is not a multiple of k then left-out nodes in the end should remain as it is.

You may not alter the values in the nodes, only nodes itself may be changed.

Only constant memory is allowed.

For example,
Given this linked list: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

题意:以k个结点为一组,进行反转连接,若最后小于k个结点,则保持不变。要求:仅用常数空间,不改变结点的值。

思路:大致过程是每k个结点一反转,直到剩余结点数小于k。遇到一个问题是:如何判断剩余结点数小于k,即循环的终止条件?这样就需要知道整条链表的总共的结点数count,然后每次反转完一组则用总的count减去k,直到最后剩余结点数小于k,就不用改变。遇到另一个问题,如何反转k个结点,这个和reverse linked list ii类似,大致的想法可以参照。这样就剩下的如何将不同的小组连接起来的问题,因为在reverse linked list ii这题中,只要反转一部分,所以其pre是不动的,这题因为有很多小组,所以pre应该是每k个结点为一小组的最开始结点的前驱,所以要移动,同理的是当前节点cur。因为要改变表头,所以要先new一个nList。使用计数器的思维值得注意。

 /**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode *reverseKGroup(ListNode *head, int k)
{
ListNode *nList=new ListNode(-);
nList->next=head;
ListNode *cur=head;
ListNode *pre=nList; int num=; //组里的结点数
int count=; //整链结点数
while(head)
{
head=head->next;
count++;
} while(count>=k) //整体遍历
{
while(++num<k) //组内循环
{
ListNode *temp=cur->next;
cur->next=temp->next;
temp->next=pre->next;
pre->next=temp;
}
count-=num;  //减k也行.
num=;
pre=cur; //每组反转以后,pre要移动
cur=cur->next; //cur要变
}
return nList->next; }
};

还有另一种写法:见Code Gander的博客,其核心思想是,每次取k个结点进行反转,传入反转函数的是这个组的前驱和其最后一个结点,反转函数返回是反转后小组的第一个结点,体会其中的差别。代码如下:

 /**   Reverse Nodes in k-Group
*
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/ //经典,很多关于list的题都可用这种方法重写
/* 使用计数器count,若count=k,则反转前k个节点,然后重置count */
class Solution {
public:
ListNode *reverseKGroup(ListNode *head, int k)
{
if(head==NULL) return NULL; ListNode *preAll=new ListNode(-);
preAll->next=head; ListNode *pre=preAll;
ListNode *cur=head;
int count=; while(cur !=NULL)
{
count++;
ListNode *last=cur->next;
if(count==k)
{
pre=reverse(pre,last);
count=;
}
cur=last;
} return preAll->next;
} //反转前k个节点,这k个点的前驱和最后一点传入
ListNode *reverse(ListNode *pre,ListNode *last)
{
if(pre==NULL||pre->next==NULL) return pre; ListNode *head=pre->next;
ListNode *cur=pre->next->next; while(cur !=last)
{
ListNode *temp=cur->next;
cur->next=pre->next;
pre->next=cur;
cur=temp;
} head->next=last;
return head; //巧妙之处是返回前节点
}
};

[Leetcode] Reverse nodes in k group 每k个一组反转链表的更多相关文章

  1. 如何k个一组反转链表

    之前的文章「递归反转链表的一部分」讲了如何递归地反转一部分链表,有读者就问如何迭代地反转链表,这篇文章解决的问题也需要反转链表的函数,我们不妨就用迭代方式来解决. 本文要解决「K 个一组反转链表」,不 ...

  2. [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 ...

  3. 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 ...

  4. 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. k  ...

  5. LeetCode Reverse Nodes in k-Group 每k个节点为一组,反置链表

    题意:给一个单链表,每k个节点就将这k个节点反置,若节点数不是k的倍数,则后面不够k个的这一小段链表不必反置. 思路:递归法.每次递归就将k个节点反置,将k个之后的链表头递归下去解决.利用原来的函数接 ...

  6. LeetCode: Reverse Nodes in k-Group 解题报告

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

  7. 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 ...

  8. leetcode Reverse Nodes in k-Group python

    # Definition for singly-linked list. # class ListNode(object): # def __init__(self, x): # self.val = ...

  9. 【Reverse Nodes in k-Group】cpp

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

随机推荐

  1. (转)程序员新人怎样在复杂代码中找 bug?

    我曾经做了两年大型软件的维护工作,那个项目有10多年了,大约3000万行以上的代码,参与过开发的有数千人,代码checkout出来有大约5个GB,而且bug特别多,open的有上千,即使最高优先级的s ...

  2. @staticmethod怎么用?

    早上起来写个小demo, 类中写了个方法, pycharm给这个方法加上了莫名其妙的波浪线, 对于一个有代码洁癖的人来说, 完全不能忍, 来看看为什么. 问题重现 pycharm的提示 上面说了, 这 ...

  3. python构造二维列表以及排序字典

    1. 构造二维列表: 比如我现在需要一个100*100的二维列表: a = [] for i in range(100): a.append([]) for j in range(100): a[i] ...

  4. Python学习 :文件操作

    文件基本操作流程: 一. 创建文件对象 二. 调用文件方法进行操作 三. 关闭文件(注意:只有在关闭文件后,才会写入数据) fh = open('李白诗句','w',encoding='utf-8') ...

  5. 50条大牛C++编程开发学习建议

    每个从事C++开发的朋友相信都能给后来者一些建议,但是真正为此进行大致总结的很少.本文就给出了网上流传的对C++编程开发学习的50条建议,总结的还是相当不错的,编程学习者(不仅限于C++学习者)如果真 ...

  6. 6 wireshark 安装使用 数据包抓取

    1.wireshark安装 2.开始使用 3.界面详情 4. 数据包抓取 5.过滤数据

  7. 完整的vue+vuex+api-router+database请求流程

  8. 判断电脑CPU硬件支不支持64位

    你可以在注册表中查看: HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Environment\PROCESSO ...

  9. lessJs

    lessJs下载地址 ======== 简介 lessJs主要提供页面切换,页面管理的一个框架:less-ui.css 和 less-ui.js 是独立于less.js的,他们提供的是一组ui,包括消 ...

  10. ExtJs4.1目录结构介绍和使用说明[转]

    一.在做ExtJs开发之前首先要到网站上下载ExtJs的开发包,我用的最新版本是4.1.1.此版本相对于之前的版本目录结构发生了一些变化,没有了adapter目录, 目录结构如下 文件/文件夹名的作用 ...