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;
    }
}

递归

暂时没思考

相关推荐
朱皮皮呀15 分钟前
排序算法-归并排序
数据结构·算法·排序算法·归并排序
jyan_敬言25 分钟前
虚拟机centos_7 配置教程(镜像源、配置centos、静态ip地址、Finalshell远程操控使用)
linux·运维·服务器·c语言·数据结构·tcp/ip·centos
UrSpecial27 分钟前
【数据结构取经之路】图解AVL树
数据结构
QXH20000028 分钟前
数据结构—顺序表
数据结构
fhvyxyci4 小时前
【数据结构初阶】顺序结构二叉树(堆)接口实现超详解
c语言·数据结构
禁默7 小时前
list从0到1的突破
数据结构·c++·list
laocooon5238578867 小时前
一个线性筛的多功能组合:筛法求质数+约数个数+约数和
数据结构·c++·算法
银氨溶液9 小时前
MySQL底层为什么选择用B+树作为索引
数据结构·数据库·b树·mysql·面试·b+树
临沂堇10 小时前
CCF刷题计划——JPEG 解码(状态方向辅助Z型填充)
数据结构·c++·算法·ccf
原来你也是码农11 小时前
(滑动窗口) LeetCode. 2398 预算内的最多机器人数目
数据结构·c++·算法·leetcode