day41(12.22)——leetcode面试经典150

61. 旋转链表

61. 旋转链表

题目:

题解:

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 head;
        }
        ListNode cur = head;
        int length = 0; 
        while(cur != null) {
            cur = cur.next;
            length++;
        }
        //k可能大于length,所以k进行取余
        k%=length;
        //如果k==length的时候就是原链表,当k取余后为0的时候也是原链表
        if(k == length || k == 0) {
            return head;
        }
        cur = head;
        int count = 0; 
        ListNode h = new ListNode();
        while(cur.next != null) {
            count++;
            if(count==length-k) {
                h = cur.next;
                cur.next = null;
                cur = h;
            }
            //防止cur.next直接为空,导致cur=cur.next,将cur置为空,再进入循环判断cur.next不为空,就会报空指针异常
            if(cur.next == null) {
                break;
            }
            cur = cur.next; 
        }
        cur.next = head;
        return h;
    }
}
相关推荐
吃好睡好便好7 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
仰泳之鹅7 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
发现一只大呆瓜8 小时前
Vite凭什么这么快?3分钟带你彻底搞懂 Vite 热更新的幕后黑手
前端·面试·vite
x_yeyue10 小时前
三角形数
笔记·算法·数论·组合数学
Patrick_Wilson10 小时前
知识沉淀的四层模型:从个人笔记到企业资产,让文档真正长出复利
面试·程序员·ai编程
橙序员小站11 小时前
人人都在鼓吹的OPC,我想给你泼盆冷水
面试·创业
念何架构之路11 小时前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星11 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
失去的青春---夕阳下的奔跑11 小时前
560. 和为 K 的子数组
数据结构·算法·leetcode
黎阳之光11 小时前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生