题解 | #牛群的重新分组#

牛群的重新分组

https://www.nowcoder.com/practice/267c0deb9a6a41e4bdeb1b2addc64c93

/*
 * function ListNode(x){
 *   this.val = x;
 *   this.next = null;
 * }
 */
/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param head ListNode类 
 * @param k int整型 
 * @return ListNode类
 */
function reverseKGroup( head ,  k ) {
    // write code here
    let dummy = new ListNode(0)
    dummy.next = head
    let pre = dummy
    let cur = head
    let count = 0
    while(cur!=null){
        count++
        if(count%k==0){
            pre = reverse(pre,cur.next)
            cur = pre.next
        }else{
            cur = cur.next
        }
    }
    return dummy.next
    function reverse(pre,end){
        let cur = pre.next
        let tail = cur
        while(cur!=end){
            let temp = cur.next      
            cur.next = pre.next      //将链表依次逆转    
            pre.next = cur           //保存反转链表的前驱结点
            cur = temp
        }
        tail.next = end              //逆转后的最后一个结点与end结点连接
        console.log(tail)
        return tail
    }
}
module.exports = {
    reverseKGroup : reverseKGroup
};

全部评论

相关推荐

找工作勤劳小蜜蜂:矛盾是没有实习,就是没实战经验,公司不想要,公司不要,你就没有实习,你就进入死循环,另外你的项目不是社会现在有大量岗位存在行业用的,云存储人员早就饱和。
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
03-19 10:38
实力求职者:真的绷不住了,第一张霸总人设,第二张求生欲拉满
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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