码迷,mamicode.com
首页 > 其他好文 > 详细

<LinkedList> (hard + 高)25

时间:2020-01-13 13:09:49      阅读:79      评论:0      收藏:0      [点我收藏+]

标签:形式   ack   eve   null   return   size   空间复杂度   node   for   

25. Reverse Nodes in k-Group

用栈的形式存储k个节点并反转,一个是用来入栈分段的,一个是用来出栈翻转的

空间复杂度O( N ) 

class Solution {
    public ListNode reverseKGroup(ListNode head, int k) {
        if(head == null) return null;
        Stack<ListNode> stack = new Stack<ListNode>();
        ListNode dummy = new ListNode(0);
        dummy.next = head;
        ListNode cur = dummy;
        ListNode next = dummy.next;
        while(next != null){
            for(int i = 0; i < k && next != null; i++){
                stack.push(next);
                next = next.next;
            }
            if(stack.size() != k) return dummy.next;
            while(stack.size() != 0){
                cur.next = stack.pop();
                cur = cur.next;
            }
            cur.next = next;
        }
        return dummy.next;
    }
}

方法二:每次调用函数都翻转一段链表。

class Solution {
    public ListNode reverseKGroup(ListNode head, int k) {
        if(head == null) return null;
        Stack<ListNode> stack = new Stack<ListNode>();
        ListNode dummy = new ListNode(0);
        dummy.next = head;
        ListNode pre = dummy;
        while(pre != null){
            pre = reverse(pre, k);
        }
        return dummy.next;
    }
    
    public ListNode reverse(ListNode pre, int k){
        ListNode last = pre;
        for(int i = 0; i < k + 1; i++){
            last = last.next;
            if(i != k && last == null) return null;
        }
        ListNode tail = pre.next;
        ListNode cur = pre.next.next;
        while(cur != last){
            ListNode next = cur.next;
            cur.next = pre.next;
            pre.next = cur;
            tail.next = next;
            cur = next;
        }
        return tail;
    }
}

<LinkedList> (hard + 高)25

标签:形式   ack   eve   null   return   size   空间复杂度   node   for   

原文地址:https://www.cnblogs.com/Afei-1123/p/12186491.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!