news 2026/5/1 10:16:43

hot100 25.K个一组翻转链表

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
hot100 25.K个一组翻转链表

思路:

1.链表分为已翻转部分 + 待翻转部分 + 未翻转部分。

2.每次翻转前,要确定翻转链表的范围,通过k次循环来确定。

3.需要记录翻转链表的前驱和后继,方便翻转完成后把已翻转和未翻转的部分连接起来。

4.初始时需要两个变量pre和end,pre表示待翻转链表的前驱,end表示待翻转链表的末尾。

5.经过k次循环,end到达末尾,记录待翻转链表的后继next = end.next。

6.翻转链表,然后将三部分链表连接起来,然后重置pre和end指针,然后进入下一次循环。

7.特殊情况:当翻转部分的长度不足k时,在定位end完成后,end == null,已经到达末尾,说明题目已经完成,直接跳出循环return即可。

复杂度分析:

1.时间复杂度:O(n*K),最好的情况为O(n),最差的情况为O(n^2)。

2.空间复杂度:O(1)。除了几个必须的节点指针外,没有占用额外空间。

附代码:

class Solution { public ListNode reverseKGroup(ListNode head, int k) { ListNode sentinel = new ListNode(0); //初始化哨兵节点 sentinel.next = head; ListNode pre = sentinel; //pre表示当前待翻转区间的前一个节点 ListNode end = sentinel; //end表示当前待翻转区间的最后一个节点 while(end.next != null){ for(int i = 0;i < k && end != null;i++){ end = end.next; //每k个节点一组 } if(end == null){ break; //剩余节点不足k个,直接退出 } ListNode start = pre.next; //start表示当前组的第一个节点 ListNode next = end.next; //next表示下一组的第一个节点 end.next = null; //断开当前组与下一组的连接 //翻转当前组 pre.next = reverse(start); //pre连接到翻转后的新头 start.next = next; //当前组的第一个节点连接下一组的第一个节点,即翻转后的尾连接到下一组的头 pre = start; //pre移动到当前组的尾部 end = pre; //end同步到pre位置 } return sentinel.next; } //翻转链表 private ListNode reverse(ListNode head){ ListNode pre = null; ListNode cur = head; while(cur != null){ ListNode tmp = cur.next; cur.next = pre; pre = cur; cur = tmp; } return pre; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 6:17:49

大模型之Token是什么?

大模型处理文本的最小单位是token&#xff08;相当于自然语言中的词或字&#xff09;&#xff0c;输出时逐个token依次生成。 收费依据 &#xff1a;大语言模型(LLM)通常也是以token的数量作为其计量(或收费)的依据。 1个Token≈1-1.8个汉字&#xff0c;1个Token≈3-4个英文字…

作者头像 李华
网站建设 2026/5/1 1:41:55

通达信平步青云 源码

{}VAR1:EMA(弱能量-过江龙*2,15); 强能量: IF(VAR1>弱能量,0,弱能量),LINETHICK0,COLORYELLOW; 江面:0,COLOR99FF99;{} STICKLINE((过江龙>强能量),过江龙,强能量,3,0),COLORRED; STICKLINE((过江龙<强能量),过江龙,强能量,3,0),COLORD4FF7F;

作者头像 李华
网站建设 2026/5/1 8:42:55

python识别图片验证码,最强验证码识别

python识别图片验证码&#xff0c;现在用得比较多&#xff0c;这是主流OCR识别对比如下&#xff1a; 下面就针对ddddocr进行使用 直接上代码&#xff1a; import ddddocrdef pngresult():data_map {}try:with open(f"doc/pngtext.txt", r) as file:data_map {lin…

作者头像 李华
网站建设 2026/5/1 8:53:24

11、v-if和v-for的优先级是什么?

v-if 和 v-for 的优先级Vue 2 中的优先级在 Vue 2 中&#xff1a;v-for 的优先级高于 v-if当它们同时出现在一个元素上时&#xff0c;v-for 会先执行<!-- Vue 2 中&#xff0c;v-for 优先级更高 --> <div v-for"item in items" v-if"item.isActive&quo…

作者头像 李华
网站建设 2026/5/1 8:51:12

强强联手!天洑软件资助西工大航模队

近日&#xff0c;天洑软件资助西北工业大学航模队&#xff0c;专注人才培养和前沿技术研发&#xff0c;用国产工业软件和技术支持&#xff0c;助力西工大航模队在航空创新领域再上新台阶。航空航天领域被誉为制造业“皇冠上的明珠”&#xff0c;是高端工业软件的应用场和练兵场…

作者头像 李华
网站建设 2026/4/27 18:47:53

2026年AI战略落地:CIO分三阶段实施框架

随着“十五五”规划的启幕与“人工智能”行动的全面推进&#xff0c;AI已成为发展的重要引擎&#xff0c;助力企业转型升级。展望2026年&#xff0c;CIO们正面临着前所未有的机遇与挑战&#xff0c;如何将人工智能战略有效落地&#xff0c;成为每位CIO的必答课题。本文提出一个…

作者头像 李华