链表中的节点每k个一组翻转

将给出的链表中的节点每 k 个一组翻转,返回翻转后的链表
如果链表中的节点数不是 k 的倍数,将最后剩下的节点保持原样
你不能更改节点中的值,只能更改节点本身。
要求空间复杂度O(1)
例如:
给定的链表是1→2→3→4→5
对于k=2, 你应该返回 2→1→4→3→5
对于k=3, 你应该返回 3→2→1→4→5

/*
 * function ListNode(x){
 *   this.val = x;
 *   this.next = null;
 * }
 */

/**
  * 
  * @param head ListNode类 
  * @param k int整型 
  * @return ListNode类
  */
function reverseKGroup( head ,  k ) {
    // write code here
    if(!head || !head.next || k === 1 ) {return head}
    var current = head
    var temp = head
    var next = null
    var limit = 0
    //查找长度是否满足反转的数量
    while(limit<k){
        if(temp == null){
            return head;
        }
        temp = temp.next
        limit++
    }
    //对k个元素进行反转
    for(let j=0;j<k;j++){
        let p = current.next
        current.next = next
        next = current
        current = p
    }
    //反转后。head.next已经成为当前反转后链表的最后一个元素,它的指向将是下一个递归的开始点
    //而此时pre已经是最后一个元素,cur是下一个范围的第一元素
    head.next = reverseKGroup(current,k)
    return next;
}
module.exports = {
    reverseKGroup : reverseKGroup
};
链表算法 文章被收录于专栏

链表相关算法

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-09 13:05
TMD找工作本来就烦,这东西什么素质啊😡
Beeee0927:hr是超雄了,不过也是有道理的
点赞 评论 收藏
分享
06-02 15:53
阳光学院 Java
点赞 评论 收藏
分享
鬼迹人途:你去投一投尚游游戏,服务器一面,第一个图算法,做完了给你一个策略题,你给出方案他就提出低概率问题,答不上当场给你挂
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-10 11:33
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务