最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

链表系列一> K 个一组翻转链表

网站源码admin4浏览0评论

链表系列一> K 个一组翻转链表

题目:

链接: link

这里是引用

解析:

这里是引用

代码:

代码语言:javascript代码运行次数:0运行复制
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    /**
    prev: 用来头插
    tmp: 每次头插前记录一下,好进行下一次头插
     */
    public ListNode reverseKGroup(ListNode head, int k) {
        ListNode cur = head;
        int n = 0;
        while(cur != null){
            cur = cur.next;
            n++;
        }
        n = n / k;//统计需要翻转链表几次

        cur = head;
        ListNode newHead = new ListNode(0);
        ListNode prev = newHead;

        for(int i = 0; i < n; i++){
            ListNode tmp = cur;
             for(int j = 0; j < k; j++){
                ListNode next = cur.next;
                cur.next = prev.next;
                prev.next = cur;
                cur = next; 
            }
            prev = tmp;
        }

        //把后面不需要逆序的连接上
        prev.next = cur; 
        return newHead.next;
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。 原始发表:2025-05-02,如有侵权请联系 cloudcommunity@tencent 删除统计classint链表连接
发布评论

评论列表(0)

  1. 暂无评论