当前位置: 首页 > news >正文

咸宁网站建设公司望野王绩朗诵

咸宁网站建设公司,望野王绩朗诵,贵州三蒲建设工程有限公司网站,装修公司找哪家比较好原题链接 难度:hard\color{red}{hard}hard 题目描述 给你链表的头节点 headheadhead , kkk 个节点一组进行翻转,请你返回修改后的链表。 kkk 是一个正整数,它的值小于或等于链表的长度。如果节点总数不是 kkk 的整数倍&#xf…

原题链接

难度:hard\color{red}{hard}hard

题目描述

给你链表的头节点 headheadheadkkk 个节点一组进行翻转,请你返回修改后的链表。

kkk 是一个正整数,它的值小于或等于链表的长度。如果节点总数不是 kkk 的整数倍,那么请将最后剩余的节点保持原有顺序。

你不能只是单纯的改变节点内部的值,而是需要实际进行节点交换。

示例 1:

输入:head = [1,2,3,4,5], k = 2
输出:[2,1,4,3,5]
复制示例输入

示例 2:

输入:head = [1,2,3,4,5], k = 3
输出:[3,2,1,4,5]
复制示例输入

提示:

  • 链表中的节点数目为 nnn
  • 1<=k<=n<=50001 <= k <= n <= 50001<=k<=n<=5000
  • 0<=Node.val<=10000 <= Node.val <= 10000<=Node.val<=1000

进阶: 你可以设计一个只用 O(1)O(1)O(1) 额外内存空间的算法解决此问题吗?


算法

(模拟)

  1. 增加虚拟头结点 dummy
  2. 对于每一轮的修改,求出 end 指针为下一轮需要交换的最后一个结点;在找 end 的过程中,若不足 k 个结点,则直接终止循环。
  3. 在找到 end 后,设置 ab 两个指针修改相邻结点之间的连接关系,需要一个临时的 c 指针来指向 bnext。(参考代码)
  4. 最终修改 p->nextc->next
  5. p 指向下一轮修改的起始位置的前一个位置。

在这里插入图片描述

C++ 代码

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode() : val(0), next(nullptr) {}*     ListNode(int x) : val(x), next(nullptr) {}*     ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:ListNode* reverseKGroup(ListNode* head, int k) {ListNode* dummy = new ListNode(0, head);for (auto p = dummy;;) {auto end = p;for (int i = 0; i < k && end != NULL; i ++) end = end->next;if (end == NULL) break;auto a = p->next, b = a->next;for (int i = 0; i < k - 1; i ++) {auto c = b->next;b->next = a;a = b, b = c;}auto c = p->next;p->next = a, c->next = b;p = c;}return dummy->next;}
};
http://www.sczhlp.com/news/103158/

相关文章:

  • .NET驾驭Word之力:COM组件二次开发全攻略之连接Word与创建你的第一个自动化文档
  • last logicflow
  • 网站app开发平台域名制作网站
  • 重庆专业网站建设公司哪家好三只松鼠网络营销模式
  • 超市网站建设吴江区桃源镇做网站
  • 哪些网站做任务可以赚钱wordpress 修改评论框
  • 邵阳哪里做网站网站建设中国站需求分析报告
  • 美食网站建设项目规划书邯郸网站设计定制
  • 泉州做网站seo的榆林网站优化
  • 个人网站建设报告十大装修公司排名哪家最好
  • 网站开发最重要的技巧中企网站案例
  • 清远 网站建设wordpress使用教学
  • 老公对我的精神虐待
  • 手机网站开发人员选项重庆公司办社保需要什么资料
  • 有趣的网站游戏最好用的手机编程软件
  • 网站开发计划书长治制作网站
  • 建站官网最新招商代理项目
  • 个人业务网站源码wordpress主题安装在哪里
  • 山西推广网站建设全球访问量最大的10个网站
  • 华与华是谁?
  • 从工具到生态:现代Bug管理系统的平台化转型之路
  • PK-CWT 系列罗氏线圈使用指南:操作方法与注意事项
  • 网站批量修改有哪些关于校园内网站建设的法律
  • 福田网站建设公司哪家性价比高卓航网站开发
  • 怎么注册域名网站国外科技感强的网站
  • 网站开发和嵌入式开发怎么做网站监控平台
  • 外贸门户网站网络培训思想汇报
  • 西部网站管理助手 伪静态来年做那个网站致富
  • 深圳彩票网站建设网站做桌面应用 iOS
  • 有几个网站能在百度做推广网站开发语言总结