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;
    }
}
相关推荐
liliangcsdn2 小时前
Python拒绝采样算法优化与微调模拟
人工智能·算法·机器学习
Christo32 小时前
2024《A Rapid Review of Clustering Algorithms》
人工智能·算法·机器学习·数据挖掘
AndrewHZ2 小时前
【图像处理基石】图像梯度:核心算法原理与经典应用场景全解析
图像处理·算法·计算机视觉·cv·算子·边缘提取·图像梯度
让学习成为一种生活方式2 小时前
组蛋白短链酰化修饰--文献精读187
算法
fei_sun2 小时前
数字图像处理
人工智能·算法·计算机视觉
Tisfy2 小时前
LeetCode 960.删列造序 III:动态规划(最长递增子序列)
算法·leetcode·动态规划·字符串·题解·逆向思维
多米Domi0112 小时前
0x3f第十天复习(考研日2)(9.18-12.30,14.00-15.00)
python·算法·leetcode
listhi5202 小时前
支持向量机多分类解决方案
算法·支持向量机·分类
十三画者2 小时前
【文献分享】vConTACT3机器学习能够实现可扩展且系统的病毒分类体系的构建
人工智能·算法·机器学习·数据挖掘·数据分析