【注释详细,思路清晰】【打卡第3天】leetcode热题HOT100之Java实现:61、旋转链表,给你一个链表的头节点 head ,旋转链表,将链表每个节点向右移动 k 个位置。

本文主要是介绍【注释详细,思路清晰】【打卡第3天】leetcode热题HOT100之Java实现:61、旋转链表,给你一个链表的头节点 head ,旋转链表,将链表每个节点向右移动 k 个位置。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、题目描述

旋转链表

给你一个链表的头节点 head ,旋转链表,将链表每个节点向右移动 k 个位置。

示例 1:

输入:head = [1,2,3,4,5], k = 2
输出:[4,5,1,2,3]

示例 2:

输入:head = [0,1,2], k = 4
输出:[2,0,1]

2、算法分析

① 将链表的每个结点向右移动k个位置,关于k讨论如下:

     旋转链表,本质上就是将尾部向前数,第K个元素作为头部,原来的头部元素接在尾上
     至于往右移动,共有两种情况:
       1、K小于链表的长度
       2、K大于链表的长度
       相当于把链表后面的结点往前移动k % len个长度
       假如 k =2 len=4,那么k%len=2,链表尾部的元素向前移动2个长度
       假如 k =4 len=3,那么k%len=1, 链表尾部的元素向前移动1个元素
       所以:
       (1)求链表的长度
       (2)找出来倒数k+1个结点
       (3)将倒第k+1个结点和倒第k个结点断开,把链表的k+1包含k+1以后的结点拼接到链表的头部

②   图解:

3、代码实现

/*** 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; }* }*//*旋转链表,本质上就是将尾部向前数,第K个元素作为头部,原来的头部元素接在尾上至于往右移动,共有两种情况:1、K小于链表的长度2、K大于链表的长度相当于把链表后面的结点往前移动k % len个长度假如 k =2 len=4,那么k%len=2,链表尾部的元素向前移动2个长度假如 k =4 len=3,那么k%len=1, 链表尾部的元素向前移动1个元素所以:(1)求链表的长度(2)找出来倒数k+1个结点(3)将倒第k+1个结点和倒第k个结点断开,把链表的k+1包含k+1以后的结点拼接到链表的头部
*/
class Solution {public ListNode rotateRight(ListNode head, int k) {// 判断头结点是否存在,头结点下一个结点是否为空,返回头结点if(head == null || head.next == null){return head;}//定义链表初识长度为0int length = 0;// 定义p指针指向头结点ListNode p = head;// 求链表长度while(p != null){// p不为空,头结点长度也要算上length++;p = p.next;}// 计算偶棉结点移动的长度k = k % length;// 如果移动的位置为0,那么返回头结点if(k == 0){return head;}// 如果k>0的话,定义移动的长度位置,slow,fastListNode slow = head;ListNode fast = head;// 移动位置的范围长度while(k > 0){fast = fast.next;k--;}// 往后移动的条件,看fast条件while(fast != null && fast.next != null){// 范围端点往后移动slow = slow.next;fast = fast.next;}// 定义新的链表的头结点ListNode newHead = slow.next;// 新链表的尾结点设置为空slow.next = null;// 新链表 结点链接fast.next = head;return newHead;}
}

 

 

这篇关于【注释详细,思路清晰】【打卡第3天】leetcode热题HOT100之Java实现:61、旋转链表,给你一个链表的头节点 head ,旋转链表,将链表每个节点向右移动 k 个位置。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/728116

相关文章

grom设置全局日志实现执行并打印sql语句

《grom设置全局日志实现执行并打印sql语句》本文主要介绍了grom设置全局日志实现执行并打印sql语句,包括设置日志级别、实现自定义Logger接口以及如何使用GORM的默认logger,通过这些... 目录gorm中的自定义日志gorm中日志的其他操作日志级别Debug自定义 Loggergorm中的

Spring Boot整合消息队列RabbitMQ的实现示例

《SpringBoot整合消息队列RabbitMQ的实现示例》本文主要介绍了SpringBoot整合消息队列RabbitMQ的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录RabbitMQ 简介与安装1. RabbitMQ 简介2. RabbitMQ 安装Spring

Gin框架中的GET和POST表单处理的实现

《Gin框架中的GET和POST表单处理的实现》Gin框架提供了简单而强大的机制来处理GET和POST表单提交的数据,通过c.Query、c.PostForm、c.Bind和c.Request.For... 目录一、GET表单处理二、POST表单处理1. 使用c.PostForm获取表单字段:2. 绑定到结

springMVC返回Http响应的实现

《springMVC返回Http响应的实现》本文主要介绍了在SpringBoot中使用@Controller、@ResponseBody和@RestController注解进行HTTP响应返回的方法,... 目录一、返回页面二、@Controller和@ResponseBody与RestController

JAVA集成本地部署的DeepSeek的图文教程

《JAVA集成本地部署的DeepSeek的图文教程》本文主要介绍了JAVA集成本地部署的DeepSeek的图文教程,包含配置环境变量及下载DeepSeek-R1模型并启动,具有一定的参考价值,感兴趣的... 目录一、下载部署DeepSeek1.下载ollama2.下载DeepSeek-R1模型并启动 二、J

nginx中重定向的实现

《nginx中重定向的实现》本文主要介绍了Nginx中location匹配和rewrite重定向的规则与应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下... 目录一、location1、 location匹配2、 location匹配的分类2.1 精确匹配2

Nginx之upstream被动式重试机制的实现

《Nginx之upstream被动式重试机制的实现》本文主要介绍了Nginx之upstream被动式重试机制的实现,可以通过proxy_next_upstream来自定义配置,具有一定的参考价值,感兴... 目录默认错误选择定义错误指令配置proxy_next_upstreamproxy_next_upst

nginx生成自签名SSL证书配置HTTPS的实现

《nginx生成自签名SSL证书配置HTTPS的实现》本文主要介绍在Nginx中生成自签名SSL证书并配置HTTPS,包括安装Nginx、创建证书、配置证书以及测试访问,具有一定的参考价值,感兴趣的可... 目录一、安装nginx二、创建证书三、配置证书并验证四、测试一、安装nginxnginx必须有"-

springboot rocketmq配置生产者和消息者的步骤

《springbootrocketmq配置生产者和消息者的步骤》本文介绍了如何在SpringBoot中集成RocketMQ,包括添加依赖、配置application.yml、创建生产者和消费者,并展... 目录1. 添加依赖2. 配置application.yml3. 创建生产者4. 创建消费者5. 使用在

Spring Retry 实现乐观锁重试实践记录

《SpringRetry实现乐观锁重试实践记录》本文介绍了在秒杀商品SKU表中使用乐观锁和MybatisPlus配置乐观锁的方法,并分析了测试环境和生产环境的隔离级别对乐观锁的影响,通过简单验证,... 目录一、场景分析 二、简单验证 2.1、可重复读 2.2、读已提交 三、最佳实践 3.1、配置重试模板