LeetCode61.旋转链表

本题有两种做法:迭代和递归

本题的本质是:将链表中后k个结点变为前k个,然后将头结点连接到尾节点

迭代

考察知识:

  • 边界条件判断
  • 链表倒k结点寻找
  • Get思想:结环
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 null;
        }
        ListNode p = head;
        int count = 1;
        while (p.next != null) {
            count++;
            p = p.next;
        }
        k = k % count;
  
        // 成环,寻找 k 结点
        p.next = head;
        for (int i = 0; i < count - k; i++) {
            p = p.next;
        }
        head = p.next;
        p.next = null;
        return head;
    }
}

递归

暂时没思考

相关推荐
星期天25 分钟前
【无标题】
数据结构·c++·算法
yuuki23323336 分钟前
【数据结构&C语言】排序大汇总
c语言·数据结构·后端·排序算法
做怪小疯子1 小时前
LeetCode 热题 100——普通数组——除自身以外数组的乘积
数据结构·算法·leetcode
明洞日记1 小时前
【数据结构手册001】从零构建程序世界的基石
数据结构·c++
树在风中摇曳2 小时前
链表五大经典面试题详解:双指针与基础操作实战
数据结构·链表
Sɪʟᴇɴᴛ໊ོ2352 小时前
Anyview数据结构第一章(按需自取)
c语言·开发语言·数据结构·算法
橘颂TA3 小时前
【剑斩OFFER】算法的暴力美学——丢失的数字
数据结构·算法·leetcode·结构与算法
xiaoye-duck4 小时前
归并排序:递归与非递归全解析
数据结构·排序算法
@卞4 小时前
高阶数据结构 --- 单调队列
数据结构·c++·算法
Live&&learn11 小时前
算法训练-数据结构
数据结构·算法·leetcode