力扣面试150题--K 个一组翻转链表

Day 35

题目描述

思路

做法:

  1. 找最后一个需要反转的元素
  2. 每个小组内进行反转
  3. 分为三类点
  4. 组内的第一个点,使用before记录这个点,用于其后面的节点指向前一个节点。移动到下一个节点。
  5. 组内不是第一个点也不是最后一个点的其余点,将该节点指向前一个节点,设置该节点为前一个节点,向后移动
  6. 组内最后一个点,先将这个点指向前一个节点,将这一组前的最后一个节点指向它,将该组的第一个元素下一个指向这个节点的下一个。记录本组最后一个元素以及下一组的第一个元素。
  7. 循环到最大的元素结束
java 复制代码
/**
 * 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 {
    public ListNode reverseKGroup(ListNode head, int k) {
       ListNode fakehead = new ListNode();
        if(k==1){
            return head;
        }
        else{
            fakehead.next = head;//空头结点
            ListNode x=head;
            int i=1;
            while(x!=null){
                x=x.next;
                i++;
            }
            int len=i-1;//统计链表长度
            int max=(len/k)*k;//最后一个需要倒序的元素
            x=head;
            i=1;
            ListNode before=head;//指向前一个节点
            ListNode beg=fakehead;//指向上一组的最后一个元素
            while(i<=max){
                if(i%k==1){//小组中第一个元素
                    before=x;
                    x=x.next;
                    i++;
                }
                else if(i%k!=1&&i%k!=0){//到小组中的元素
                    ListNode xia=x.next;
                    x.next=before;
                    before=x;
                    x=xia;
                    i++;
                }
                else{//小组中最后一个元素
                    ListNode xia=x.next;
                    x.next=before;
                    ListNode s=beg.next;
                    beg.next=x;
                    s.next=xia;
                    beg=s;
                    x=xia;
                    i++;
                }
            }
        }
        return fakehead.next;  
    }
}
相关推荐
over6975 小时前
从 LLM 到全栈 Agent:MCP 协议 × RAG 技术如何重构 AI 的“做事能力”
面试·llm·mcp
SuperEugene6 小时前
Vue状态管理扫盲篇:如何设计一个合理的全局状态树 | 用户、权限、字典、布局配置
前端·vue.js·面试
Sailing8 小时前
🚀 别再乱写 16px 了!CSS 单位体系已经进入“计算时代”,真正的响应式布局
前端·css·面试
SuperEugene10 小时前
Vue状态管理扫盲篇:Vuex 到 Pinia | 为什么大家都在迁移?核心用法对比
前端·vue.js·面试
Hilaku11 小时前
我会如何考核一个在简历里大谈 AI 提效的高级前端?
前端·javascript·面试
前端Hardy11 小时前
别再用 $emit 满天飞了!Vue 3 组件通信的 4 种正确姿势,第 3 种 90% 的人不知道
前端·vue.js·面试
我叫黑大帅11 小时前
前端如何利用 GitHub Actions 自动构建并发布到 GitHub Pages?
前端·面试·github
我叫黑大帅11 小时前
前端总说的防抖与节流到底是什么?
前端·javascript·面试
掘金安东尼11 小时前
从平面到空间:用 React Three Fiber 构建 3D 产品网格
前端·javascript·面试
swipe11 小时前
#用这 9 个浏览器 API,我把页面从“卡成 PPT”救回到 90+(每个都有能直接抄的例子)
前端·javascript·面试