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

一、题目

二、实现

import java.util.*;

/*
 * 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) {
        // 1.定义一个栈
        Stack<ListNode> stack = new Stack<>();
        // 2. 初始化链表,存放结果
        ListNode res = new ListNode(0);
        // 3. 定义结果链的指针
        ListNode p = res;
        // 4. 通过栈,实现子链表反转
        while(true){
            //1. 当前子链表的开始位置(head记录当前子链的头部)
            ListNode temp = head; 
            //2. 记录反转的结点数
            int count = 0;
            while(count<k && temp!=null){
                stack.push(temp);
                temp = temp.next;
                count++;
            }
            //3. 如果最后的元素不足k,不进行反转,直接加到结果链,退出
            if(count<k){
                p.next = head;
                break;
            }
            //4. 将栈中元素出栈,加到结果链中
            while(!stack.isEmpty()){
                p.next = stack.pop();
                p = p.next;
            }
            //5. 更新下一个子链的头部
            head = temp;
        }
        return res.next;
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值