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;
    }
}
相关推荐
仰泳的熊猫3 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
似水明俊德6 小时前
02-C#.Net-反射-面试题
开发语言·面试·职场和发展·c#·.net
无极低码6 小时前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
软件算法开发6 小时前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
无限大67 小时前
AI实战03:Java开发岗专属工作流|用AI辅助代码审查与文档生成
面试
superior tigre7 小时前
22 括号生成
算法·深度优先
程序员雨果8 小时前
软件测试工程师:面试题与经验分享
软件测试·面试·职场和发展
Yvonne爱编码8 小时前
2026年计算机专业求职指南:从简历优化到技术面试通关【科普类】
面试·职场和发展
测试界的飘柔8 小时前
月薪 20k 的性能测试面试题大曝光,让你如何迅速拿下 offer!
自动化测试·软件测试·功能测试·面试·职场和发展·职场经验·找工作