#include "000库函数.h"

 struct ListNode {
int val;
ListNode *next;
ListNode(int x) : val(x), next(NULL) {}
};
/************************自己解答****************************/
//不含头结点,链表中的数据按照k个k个地翻转,使用栈进栈出原理
class Solution {
public:
ListNode* reverseKGroup(ListNode* head, int k) {
if (k <= || !head || !(head->next))return head;
ListNode* Res = new ListNode();
ListNode* r = Res;
ListNode* p = head;
stack<int> S;
while (p) {
S.push(p->val);
p = p->next;
if (S.size() == k) {
while (!S.empty()) { //采用尾插法
ListNode* q = new ListNode();
q->val = S.top();
r->next = q;
r = q;
S.pop();
}
}
}
if (S.size()) {
while (!S.empty()) { //采用头插法
ListNode* q = new ListNode();
q->val = S.top();
q->next = r->next;
r->next = q;
S.pop();
}
}
return Res->next; } }; /*******************************博客答案***************************/
//这道题让我们以每k个为一组来翻转链表,实际上是把原链表分成若干小段,
//然后分别对其进行翻转,那么肯定总共需要两个函数,一个是用来分段的,
//一个是用来翻转的,我们就以题目中给的例子来看,对于给定链表1->2->3->4->5,
//一般在处理链表问题时,我们大多时候都会在开头再加一个dummy node,因为翻转链表时头结点可能会变化
//为了记录当前最新的头结点的位置而引入的dummy node,那么我们加入dummy node后的链表变为
//- 1->1->2->3->4->5,如果k为3的话,我们的目标是将1, 2, 3翻转一下,那么我们需要一些指针
//,pre和next分别指向要翻转的链表的前后的位置,然后翻转后pre的位置更新到如下新的位置: //复制代码
//- 1->1->2->3->4->5
//| | |
//pre cur next
//
//- 1->3->2->1->4->5
//| | |
//cur pre next
//复制代码 //以此类推,只要cur走过k个节点,那么next就是cur->next,
//就可以调用翻转函数来进行局部翻转了,注意翻转之后新的cur和pre的位置都不同了,
//那么翻转之后,cur应该更新为pre->next,而如果不需要翻转的话,cur更新为cur->next, //解法一://耗时超过自己的解答 class Solution {
public:
ListNode* reverseKGroup(ListNode* head, int k) {
if (!head || k == ) return head;
ListNode *dummy = new ListNode(-), *pre = dummy, *cur = head;
dummy->next = head;//添加头结点
for (int i = ; cur; ++i) {
if (i % k == ) {
pre = reverseOneGroup(pre, cur->next);
cur = pre->next;
}
else {
cur = cur->next;
}
}
return dummy->next;
}
ListNode* reverseOneGroup(ListNode* pre, ListNode* next) {
ListNode *last = pre->next, *cur = last->next;
while (cur != next) {
last->next = cur->next;
cur->next = pre->next;
pre->next = cur;
cur = last->next;
}
return last;
}
}; //我们也可以在一个函数中完成,我们首先遍历整个链表,统计出链表的长度,
//然后如果长度大于等于k,我们开始交换节点,当k = 2时,每段我们只需要交换一次,
//当k = 3时,每段需要交换2此,所以i从1开始循环,注意交换一段后更新pre指针,然后num自减k
//直到num < k时循环结束,参见代码如下: //解法二:时间更长!!!! class Solution {
public:
ListNode* reverseKGroup(ListNode* head, int k) {
ListNode *dummy = new ListNode(-), *pre = dummy, *cur = pre;
dummy->next = head;
int num = ;
while (cur = cur->next) ++num;
while (num >= k) {
cur = pre->next;
for (int i = ; i < k; ++i) {
ListNode *t = cur->next;
cur->next = t->next;
t->next = pre->next;
pre->next = t;
}
pre = cur;
num -= k;
}
return dummy->next;
}
}; //我们也可以使用递归来做,我们用head记录每段的开始位置,cur记录结束位置的下一个节点,
//然后我们调用reverse函数来将这段翻转,然后得到一个new_head,原来的head就变成了末尾,
//这时候后面接上递归调用下一段得到的新节点,返回new_head即可,参见代码如下: class Solution {
public:
ListNode* reverseKGroup(ListNode* head, int k) {
ListNode *cur = head;
for (int i = ; i < k; ++i) {
if (!cur) return head;
cur = cur->next;
}
ListNode *new_head = reverse(head, cur);
head->next = reverseKGroup(cur, k);
return new_head;
}
ListNode* reverse(ListNode* head, ListNode* tail) {
ListNode *pre = tail;
while (head != tail) {
ListNode *t = head->next;
head->next = pre;
pre = head;
head = t;
}
return pre;
}
}; void T025() {
ListNode* N = new ListNode();
ListNode* p = N;
for (int i = ; i < ; ++i) {
ListNode* q = new ListNode();
q->val = i + ;
p->next = q;
p = q;
}
p = N->next;
cout << "原:";
while (p) {
cout << p->val << '\t';
p = p->next;
}
cout << endl;
Solution S;
p = S.reverseKGroup(N->next,);
cout << "转:";
while (p) {
cout << p->val << '\t';
p = p->next;
}
cout << endl; }

025k个一组翻转链表的更多相关文章

  1. [LintCode] 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. leetcode 25. K 个一组翻转链表

    # coding:utf-8 __author__ = "sn" """ 25. K 个一组翻转链表 给你一个链表,每 k 个节点一组进行翻转,请你返 ...

  3. LeetCode 25. K 个一组翻转链表 | Python

    25. K 个一组翻转链表 题目来源:https://leetcode-cn.com/problems/reverse-nodes-in-k-group 题目 给你一个链表,每 k 个节点一组进行翻转 ...

  4. Java实现 LeetCode 25 K个一组翻转链表

    25. K 个一组翻转链表 给你一个链表,每 k 个节点一组进行翻转,请你返回翻转后的链表. k 是一个正整数,它的值小于或等于链表的长度. 如果节点总数不是 k 的整数倍,那么请将最后剩余的节点保持 ...

  5. LeetCoded第25题题解--K个一组翻转链表--java--链表

    链表 单链表:链表中的每个元素实际上是一个单独的对象,而所有对象都通过每个元素的引用字段链接在一起. 双链表:与单链表不同的是,双链表的每个节点都含有两个引用字段. 链表优点 灵活分配内存空间 能在O ...

  6. leetcode 24. 两两交换链表中的节点 及 25. K 个一组翻转链表

    24. 两两交换链表中的节点 问题描述 给定一个链表,两两交换其中相邻的节点,并返回交换后的链表. 你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换. 示例: 给定 1->2-> ...

  7. LeetCode-025-K 个一组翻转链表

    K 个一组翻转链表 题目描述:给你一个链表,每 k 个节点一组进行翻转,请你返回翻转后的链表. k 是一个正整数,它的值小于或等于链表的长度. 如果节点总数不是 k 的整数倍,那么请将最后剩余的节点保 ...

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

  9. k个一组翻转链表(java实现)

    题目: 给出一个链表,每 k 个节点一组进行翻转,并返回翻转后的链表. k 是一个正整数,它的值小于或等于链表的长度.如果节点总数不是 k 的整数倍,那么将最后剩余节点保持原有顺序. 示例 : 给定这 ...

随机推荐

  1. CLR via c# 值类型“不可变”

    昨天看书看到引用类型和值类型,书中讲到值类型“不可变”,如图: 看了两遍没怎么看懂,又仔细多看了几遍,说下我的理解: 比如说一个int类型有几个成员, MaxValue.MinValue的值是不可变的 ...

  2. SQL去除数据库表中tab、空格、回车符等特殊字符的解决方法

    按照ASCII码, SELECT char(64) 例如64 对应 @,则 ), 'kk'); 则结果为 abckkqq.com 依此类推, 去掉其他特殊符号,参考ASCII码对照表, 去掉tab符号 ...

  3. MongoDB日期类型查询

    一.前言 MongoDB 里面的日期类型是没有时区概念的,默认存储的是 ISODate("2018-04-02T13:19:16.418Z") 这种格式的零时区时间,比北京时间晚了 ...

  4. No.3 数组中重复的数字 (P39)

    题目1:找出数组中重复的数字 [题目描述] 在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一个 ...

  5. GitHub:我们是这样弃用jQuery的

    摘要: 技术债清理流程指南. 原文:Removing jQuery from GitHub.com frontend 译文:GitHub:我们为什么会弃用jQuery? 作者:GitHub 前端工程团 ...

  6. Module的加载实现

    烂笔头开始记录小知识点啦- 浏览器要加载 ES6模块,: <script type="module" src="./foo.js"></scr ...

  7. WePY - 小程序敏捷开发实践丨掘金开发者大会

    声明:内容转载他处,如有侵权,可协商下架 本主题虽然在其它地方讲了很多次,但还是有非常多新内容.因为很多东西正在做或者想要做.本次分享主要分为以下几个部分: WePY 的介绍 WePY 的用户 上面展 ...

  8. 用js实现博客打赏功能

    前几天在一个博客中看到有一个打赏功能.其实简单说来就是在页面中加入动态DOM节点,使用的也是简单的HTML.CSS.JS这些前端的一些简单知识.在GitHub上有开源的代码,这里稍加改造就可以用在自己 ...

  9. 讲讲网络模块中加解密那点儿事--AES+BASE64

    本篇文章已授权微信公众号 dasuAndroidTv(大苏)独家发布 这次想来讲讲网络安全通信这一块,也就是网络层封装的那一套加密.解密,编码.解码的规则,不会很深入,但会大概将这一整块的讲一讲. 之 ...

  10. 《JavaScript高级程序设计》笔记:基本概念(三)

    数据类型 ECMAScript中有5种简单数据类型(也称为基本数据类型):undefined,null,boolean,number和string. typeof typeof null会返回“obj ...