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;
    }
}
相关推荐
Chat_zhanggong34514 小时前
主推NT98336BG作用有哪些?
嵌入式硬件·算法
Run_Teenage14 小时前
算法:线段树
算法
Westward-sun.14 小时前
YOLOv2算法全方位解析:从BatchNorm到聚类先验框的九大改进
算法·yolo·聚类
扶苏xw14 小时前
【离散化算法】
算法
码之气三段.14 小时前
Codeforces Round 1095 (Div. 2) 补题
算法
6Hzlia14 小时前
【Hot 100 刷题计划】 LeetCode 189. 轮转数组 | C++ 三次反转经典魔法 (O(1) 空间)
c++·算法·leetcode
wuweijianlove15 小时前
算法可扩展性建模与渐进性能分析的技术7
算法
许彰午15 小时前
CacheSQL:一个面向政务系统的内存缓存数据库中间件
java·数据库·缓存·中间件·面试·开源软件·政务
不会敲代码115 小时前
从 URL 到页面展示,还有哪些你忽略的底层细节?(DNS 与传输篇)
前端·面试
AI人工智能+电脑小能手15 小时前
【大白话说Java面试题】【Java基础篇】第21题:HashMap和Hashtable的区别是什么
java·开发语言·面试·哈希算法·散列表·hash table