Reverse K-group linked list
难度:Medium; 类型: linkedlist; 公司:字节研发,华为等
Last updated
难度:Medium; 类型: linkedlist; 公司:字节研发,华为等
Last updated
将给出的链表中的节点每 k k 个一组翻转,返回翻转后的链表 如果链表中的节点数不是 k k 的倍数,将最后剩下的节点保持原样 你不能更改节点中的值,只能更改节点本身。 要求空间复杂度 O(1) O(1) 例如: 给定的链表是1→2→3→4→5 对于 k = 2 k=2, 你应该返回 2→1→4→3→5 对于 k = 3 k=3, 你应该返回3→2→1→4→5 示例1
复制复制
复制复制
找linkedlist的每个group的head和end
由于reverse后的linkedlist的head会变动,需要先fakehead使fakehead的next始终是list的head
之后用two pointer的方法,slowpointer指向group的head的前一个node,而fast 指向group的end在把fast不断向前移动时用counter记录它的位置来如果counter %k=0那么就是group的end
把group先cut出来进行reverse,然后返回新的group head 和end,再把它接上去原来的list
把 slow更新到fast
把每个group的head 和end的部分进行reverse
因为要对每一个node的next进行翻转,需要cur pointer 遍历每个node
需要prev保存cur的上一个node翻转,同时也要next保持cur的下一个node用于先前移动
new tail就是原来的list的head, new head就是最后的prev