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;
    }
}
相关推荐
Learn Beyond Limits14 分钟前
解构语义:从词向量到神经分类|Decoding Semantics: Word Vectors and Neural Classification
人工智能·算法·机器学习·ai·分类·数据挖掘·nlp
你怎么知道我是队长39 分钟前
C语言---typedef
c语言·c++·算法
Qhumaing2 小时前
C++学习:【PTA】数据结构 7-1 实验7-1(最小生成树-Prim算法)
c++·学习·算法
踩坑记录4 小时前
leetcode hot100 3.无重复字符的最长子串 medium 滑动窗口(双指针)
python·leetcode
Z1Jxxx4 小时前
01序列01序列
开发语言·c++·算法
汽车仪器仪表相关领域5 小时前
全自动化精准检测,赋能高效年检——NHD-6108全自动远、近光检测仪项目实战分享
大数据·人工智能·功能测试·算法·安全·自动化·压力测试
懒猫爱上鱼5 小时前
Android 14 中 AMS 对进程优先级的完整管控机制
面试
Doro再努力5 小时前
【数据结构08】队列实现及练习
数据结构·算法
清铎7 小时前
leetcode_day12_滑动窗口_《绝境求生》
python·算法·leetcode·动态规划