题解 | #链表中的节点每k个一组翻转#

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

http://www.nowcoder.com/practice/b49c3dc907814e9bbfa8437c251b028e

import java.util.*;

/*
 * public class ListNode {
 *   int val;
 *   ListNode next = null;
 * }
 */

public class Solution {
    /**
     * 相隔k个反转一次!
     * @param head ListNode类 
     * @param k int整型 
     * @return ListNode类
     */
    public ListNode reverseKGroup (ListNode head, int k) {
        // write code here
        ListNode fake_head = new ListNode(-1);
        fake_head.next = head;
        ListNode pre = fake_head;
        ListNode cur = null;
        ListNode tail = head;
            
        while(tail != null){
            int count = 0;
            cur = tail;
            while(count < k && tail != null){
                tail = tail.next;
                count++;
            }
            if(count < k){
                break;
            }
            ListNode next = pre.next;
            pre.next = reverse(cur,tail);
            pre = next;
        }  
        return fake_head.next;
    }
    
    private ListNode reverse(ListNode head,ListNode tail){
        ListNode cur = head,pre = null,next = null;
        while(cur != tail){
            next = cur.next;
            cur.next = pre;
            pre = cur;
            cur = next;
        }
        head.next = tail;
        return pre;
    }
    
    
}
全部评论

相关推荐

风中翠竹:真的真的真的没有kpi。。。面试官是没有任何kpi的,捞是真的想试试看这个行不行,碰碰运气,或者是面试官比较闲现在,没事捞个人看看。kpi算HR那边,但是只有你入职了,kpi才作数,面试是没有的。
双非有机会进大厂吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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