力扣面试150题--旋转链表

Day 38

题目描述

思路

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 rotateRight(ListNode head, int k) {
        if(head==null){//处理空链表
            return null;
        }
         ListNode fakehead=new ListNode();
        fakehead.next=head;//空头结点
        ListNode z=fakehead;
        ListNode x=head;
        int len=1;
        while(x.next!=null){//找到链表长度
            x=x.next;
            len++;
        }
        k=k%len;//防止k大于len
        if(k==0){//说明k被除尽了 不需要处理
            return head;
        }
        ListNode y=head;
        x=head;
        int i=1;
        while(i!=k){
            y=y.next;
            i++;
        }
        while(y.next!=null){
            z=z.next;
            x=x.next;
            y=y.next;
        }//以上代码复用了找到倒数第k个元素,z为倒数第k+1的元素
        //x为倒数第k个元素
        z.next=null;//此时旋转,k为最后一个,指向null
        y.next=fakehead.next;//结尾变为空头指针的后一个
        fakehead.next=x;//空头指针指向倒数第k个元素
        return fakehead.next;//建议画图理解
    }
}
相关推荐
coder_Eight11 分钟前
彻底吃透 Promise:从状态、链式到手写实现,再到 async/await 底层原理
javascript·面试
AlenTech1 小时前
139. 单词拆分 - 力扣(LeetCode)
算法·leetcode·职场和发展
阿隅1 小时前
从一道前端面试题,聊到朋友做实时通信时的心跳检测
面试
郝学胜-神的一滴2 小时前
巧解括号序列分解问题:栈思想的轻量实现
开发语言·数据结构·c++·算法·面试
穿条秋裤到处跑2 小时前
每日一道leetcode(2026.03.30):判断通过操作能否让字符串相等 II
算法·leetcode
Q741_1472 小时前
每日一题 力扣 2840. 判断通过操作能否让字符串相等 II 力扣 2839. 判断通过操作能否让字符串相等 I 找规律 字符串 C++ 题解
c++·算法·leetcode·力扣·数组·找规律
我真不是小鱼3 小时前
cpp刷题打卡记录24——路径总和 & 路径总和II
数据结构·c++·算法·leetcode
nianniannnn3 小时前
力扣 347. 前 K 个高频元素
c++·算法·leetcode
x_xbx3 小时前
LeetCode:217. 存在重复元素
数据结构·leetcode·哈希算法
Frostnova丶3 小时前
LeetCode 2839. 判断通过操作能否让字符串相等 I
算法·leetcode