Leetcode(25)- k个一组翻转链表
给出一个链表,每 k 个节点一组进行翻转,并返回翻转后的链表。
k 是一个正整数,它的值小于或等于链表的长度。如果节点总数不是 k 的整数倍,那么将最后剩余节点保持原有顺序。
示例 :
给定这个链表:1->2->3->4->5
当 k = 2 时,应当返回: 2->1->4->3->5
当 k = 3 时,应当返回: 3->2->1->4->5
说明 :
- 你的算法只能使用常数的额外空间。
- 你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。
思路:前面有个题目是两两交换链表中的节点,那个我就不写了,因为只涉及到链表节点交换的指针指向问题,需要注意的点是头结点的处理,还有交换完之后变换指向的问题。现在这个问题是要交换k个节点,不满k个节点的不处理。既然要把k个节点反向,很容易想到栈的结构,但是如果不满k个的时候,又还要正向,所以我又加了队列这个结构。实现起来麻烦了点,但是所幸实现了,注意的点依然是头结点的处理。
ListNode* reverseKGroup(ListNode* head, int k)
{
if(!head) return NULL;
ListNode* newhead,*newcur;
newhead=NULL;
stack<ListNode*> temp;
queue<ListNode*> q;
ListNode* cur;
cur=head;
while(cur)
{
if(temp.size()!=k)
{
temp.push(cur);
q.push(cur);
}
else
{
while(!temp.empty())
{
if(!newhead)
{
newhead=new ListNode(temp.top()->val);
newcur=newhead;
}
else
{
newcur->next=new ListNode(temp.top()->val);
newcur=newcur->next;
}
temp.pop();
q.pop();
}
continue;
}
cur=cur->next;
}
if(temp.size()==k)
{
while(!temp.empty())
{
if(!newhead)
{
newhead=new ListNode(temp.top()->val);
newcur=newhead;
}
else
{
newcur->next=new ListNode(temp.top()->val);
newcur=newcur->next;
}
temp.pop();
}
}
else
{
while(!q.empty())
{
if(!newhead)
{
newhead=new ListNode(q.front()->val);
newcur=newhead;
}
else
{
newcur->next=new ListNode(q.front()->val);
newcur=newcur->next;
}
q.pop();
}
}
return newhead;
}
我看着都爆炸,因为我忽略了,既然同时涉及正向与反向的问题,我反而不如直接用vector结构,更加省事。满k个的时候,反向遍历添加节点,个数不足k的时候,正向遍历添加节点。
ListNode* reverseKGroup(ListNode* head, int k)
{
ListNode* newHead = NULL, *cur = NULL;
while (head)
{
vector<ListNode*> nodes;
while (nodes.size() < k && head)
{
nodes.push_back(head);
head = head->next;
}
if (nodes.size() == k)
{
for (int i = k - 1;i >= 0;--i)
{
if (i > 0)
{
nodes[i]->next = nodes[i-1];
}
else
{
nodes[i]->next = head;
}
}
if (newHead == NULL)
{
newHead = nodes[k-1];
}
if (cur)
{
cur->next = nodes[k-1];
}
cur = nodes[0];
}
else
{
if (newHead == NULL)
{
newHead = nodes[0];
}
if (cur)
{
cur->next = nodes[0];
}
cur = nodes.back();
}
}
return newHead;
}
Leetcode(25)- k个一组翻转链表的更多相关文章
- Java实现 LeetCode 25 K个一组翻转链表
25. K 个一组翻转链表 给你一个链表,每 k 个节点一组进行翻转,请你返回翻转后的链表. k 是一个正整数,它的值小于或等于链表的长度. 如果节点总数不是 k 的整数倍,那么请将最后剩余的节点保持 ...
- leetcode 25. K 个一组翻转链表
# coding:utf-8 __author__ = "sn" """ 25. K 个一组翻转链表 给你一个链表,每 k 个节点一组进行翻转,请你返 ...
- LeetCode 25. K 个一组翻转链表 | Python
25. K 个一组翻转链表 题目来源:https://leetcode-cn.com/problems/reverse-nodes-in-k-group 题目 给你一个链表,每 k 个节点一组进行翻转 ...
- [LeetCode] 25. k个一组翻转链表
题目链接: https://leetcode-cn.com/problems/reverse-nodes-in-k-group/ 题目描述: 给出一个链表,每 k 个节点一组进行翻转,并返回翻转后的链 ...
- LeetCode 25 —— K 个一组翻转链表
1. 题目 2. 解答 首先,利用快慢指针确定链表的总结点数. 偶数个结点时,结点个数等于 i * 2. 奇数个结点时,结点个数等于 i * 2 + 1. 然后将链表的每 K 个结点划分为一组.循环对 ...
- [LeetCode] 25. K 个一组翻转链表 ☆☆☆☆☆(链表)
https://leetcode-cn.com/problems/reverse-nodes-in-k-group/solution/javadi-gui-fang-fa-100-by-chadriy ...
- LeetCode 25. k个一组翻转链表(Reverse Nodes in k-Group)
题目描述 给出一个链表,每 k 个节点一组进行翻转,并返回翻转后的链表. k 是一个正整数,它的值小于或等于链表的长度.如果节点总数不是 k 的整数倍,那么将最后剩余节点保持原有顺序. 示例 : 给定 ...
- leetcode 24. 两两交换链表中的节点 及 25. K 个一组翻转链表
24. 两两交换链表中的节点 问题描述 给定一个链表,两两交换其中相邻的节点,并返回交换后的链表. 你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换. 示例: 给定 1->2-> ...
- [链表]LeetCode 25 K组一个翻转链表
LeetCode 25 k组一个翻转链表 TITLE 示例 1: 输入:head = [1,2,3,4,5], k = 2 输出:[2,1,4,3,5] 示例 2: 输入:head = [1,2,3, ...
- Leetcode题库——25.k个一组翻转链表
@author: ZZQ @software: PyCharm @file: ReverseList.py @time: 2018/11/6 15:13 题目要求:给出一个链表,每 k 个节点一组进行 ...
随机推荐
- widnows2008双网卡双ip不同Ip段
机房内有不同段ip,因为线路不一样,比如普通带宽和cn2带宽,现有需求配置双网卡双ip ip1: 121.7*.*.* 255.255.255.192 121.7*.*129 ip2: 103.11 ...
- mybatis框架整合及逆向工程
mybatis框架整合及逆向工程 一.三大框架整合 整合SSM框架 1.导入pom文件 1.导入spring的pom依赖 <?xml version="1.0" enco ...
- Java并发组件二之CyclicBarriar
使用场景: 多个线程相互等待,直到都满足条件之后,才能执行后续的操作.CyclicBarrier描述的是各个线程之间相互等待的关系. 使用步骤: 正常实例化:CyclicBarrier sCyclic ...
- git commit,启动文本编辑器
git commit中输入message的几种方式 - 简书 https://www.jianshu.com/p/ad461b99e860 在所有的git教程里,git commit肯定是一开始就会提 ...
- (SqlServe)关于字符串长度被截断的问题
1. 问题描述 在同步数据时常常会发现一个错误:将截断字符串或二进制数据. 2. 问题原因 这个问题出现的原因是:要插入的数值字段的长度超出了数据库中字段的长度.比如:插入的字符串字节长度是40,数据 ...
- 【转载】【网络安全】渗透中 PoC、Exp、Payload 与 Shellcode 的区别
原文地址 渗透中 PoC.Exp.Payload 与 Shellcode 的区别 概念 PoC,全称"Proof of Concept",中文"概念验证",常指 ...
- CF1433F Zero Remainder Sum
写在前面 思维难度不是很大的 DP,代码实现也很容易. 状态设计模式很套路,转移也很好理解. 算法思路 (因为 \(k\) 是常用的循环变量,下文中将题面中的模数改为 \(p\)) 虽然要求的是模 \ ...
- Web信息收集-目标扫描-OpenVAS
Web信息收集-目标扫描-OpenVAS 一.OpenVAS简述 二.部署OpenVAS 2.1 升级Kali Linux 2.2 安装OpenVAS 2.3 修改admin账户密码 2.4 修改默认 ...
- JDBC的操作步骤和实例()
加载JDBC驱动程序 提供JDBC连接的URL 创建数据库的连接 创建一个Statement 执行SQL语句 处理结果 关闭JDBC对象 实例JdbcUtils 创建一个JDBC程序包含7个步骤: 1 ...
- SparkStreaming与Kafka,SparkStreaming接收Kafka数据的两种方式
SparkStreaming接收Kafka数据的两种方式 SparkStreaming接收数据原理 一.SparkStreaming + Kafka Receiver模式 二.SparkStreami ...