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

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

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


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

public class Solution {
    /**
     * 
     * @param head ListNode类 
     * @param k int整型 
     * @return ListNode类
     */
    public ListNode reverseKGroup (ListNode head, int k) {
        // write code here
        if(k<=0 || head == null){
            return head;
        }
        ListNode newHead = new ListNode(-1);
        //每次的头结点
        ListNode currentNode = newHead;
         
        
        while(true){
            int i = 0;
            ListNode nextPos = head;
            ListNode temp ;
            for(;i< k && head != null;i++){
                temp = head.next;
                head.next = currentNode.next;
                currentNode.next = head;
                head = temp;
            }
            if(i == k){
                //每次翻转前的第一个节点 保持翻转后连接起来
                currentNode = nextPos;
            }else{
                //后面不足k 也翻转了,需要再次翻转过来
                //head = currentNode.next 最后一组里一个节点
                for(head = currentNode.next,currentNode.next = null;head!=null;){
                    temp = head.next;
                    head.next = currentNode.next;
                    currentNode.next = head;
                    head = temp;
                    
                }
                break;
            }
            
            
            
        }
        
        return newHead.next;
    }
}
全部评论

相关推荐

10-09 00:50
已编辑
长江大学 算法工程师
不期而遇的夏天:1.同学你面试评价不错,概率很大,请耐心等待;2.你的排名比较靠前,不要担心,耐心等待;3.问题不大,正在审批,不要着急签其他公司,等等我们!4.预计9月中下旬,安心过节;5.下周会有结果,请耐心等待下;6.可能国庆节前后,一有结果我马上通知你;7.预计10月中旬,再坚持一下;8.正在走流程,就这两天了;9.同学,结果我也不知道,你如果查到了也告诉我一声;10.同学你出线不明朗,建议签其他公司保底!11.同学你找了哪些公司,我也在找工作。
点赞 评论 收藏
分享
ArisRobert:统一解释一下,第4点的意思是,公司按需通知员工,没被通知到的员工是没法去上班的,所以只要没被通知到,就自动离职。就是一种比较抽象的裁员。
点赞 评论 收藏
分享
评论
1
收藏
分享
牛客网
牛客企业服务