61.旋转链表--字节跳动
你应该比你现在强得多
题目描述
给定单链表,要求返回向右移动K位后的新链表

输入:head = [1,2,3,4,5], k = 2
输出:[4,5,1,2,3]
思路分析
-
计算链表的长度
-
计算实际需要移动的步数
-
找到新的头节点
-
断开链表并重新连接

完整代码
/*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(nullptr) {}* ListNode(int x) : val(x), next(nullptr) {}* ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:ListNode* rotateRight(ListNode* head, int k) {// 边界条件检查:如果链表为空、只有一个节点或 k 为 0,直接返回原链表if (head==NULL || head->next==NULL || k == 0) {return head;}// 1. 计算链表的长度int n = 1; // 链表长度初始化为 1,因为从第一个节点开始ListNode* tail = head; // tail 指针用于找到链表的末尾节点while (tail->next) { // 遍历链表直到最后一个节点tail = tail->next; // 移动到下一个节点n++; // 计数器增加}// 2. 计算实际需要移动的步数k = k % n; // k 对链表长度取模,避免不必要的重复旋转if (k == 0) {return head; // 如果 k 为 0,说明不需要旋转,直接返回原链表}// 3. 找到新的头节点ListNode* newTail = head; // newTail 指针用于找到旋转后新的尾节点for (int i = 0; i < n - k - 1; i++) { // 移动到新尾节点的位置(n - k - 1)newTail = newTail->next; // 移动到下一个节点}ListNode* newHead = newTail->next; // 新头节点是新尾节点的下一个节点// 4. 断开链表并重新连接newTail->next = nullptr; // 断开新尾节点与新头节点的连接tail->next = head; // 将原链表的尾节点连接到原链表的头节点,形成环return newHead; // 返回旋转后的新头节点}
};
分析逻辑
1. 边界条件检查
-
如果链表为空(
head==NULL),或者链表只有一个节点(head->next==NULL),或者k为 0,直接返回原链表。 -
这些情况下链表不需要进行任何旋转操作。
2. 计算链表长度
-
使用
tail指针从链表头开始遍历,直到链表的末尾(tail->next为nullptr)。 -
在遍历过程中,计数器
n记录链表的长度。
3. 计算实际移动步数
-
由于旋转
k次相当于旋转k % n次,因为旋转n次后链表会回到原来的状态。 -
如果
k % n == 0,说明不需要旋转,直接返回原链表。
4. 找到新的头节点
-
使用
newTail指针从链表头开始,移动n - k - 1步,到达旋转后的新尾节点。 -
newTail->next就是旋转后的新头节点。
5. 断开链表并重新连接
-
将新尾节点 (
newTail) 的next指针设为nullptr,断开与新头节点的连接。 -
将原链表的尾节点 (
tail) 的next指针指向原链表的头节点 (head),形成一个新的链表环。 -
返回新的头节点
newHead,完成链表的旋转操作。
总结
-
该算法通过计算链表长度和实际旋转步数,找到新的头节点和尾节点,并重新连接链表,实现链表的右旋转。
-
时间复杂度为 O(n),空间复杂度为O(1) 。
相关文章:
61.旋转链表--字节跳动
你应该比你现在强得多 题目描述 给定单链表,要求返回向右移动K位后的新链表 输入:head [1,2,3,4,5], k 2 输出:[4,5,1,2,3]思路分析 计算链表的长度 计算实际需要移动的步数 找到新的头节点 断开链表并重新连接 完整代码 /*** Defini…...
verilog笔记
Verilog学习笔记(一)入门和基础语法BY电棍233 由于某些不可抗拒的因素和各种的特殊原因,主要是因为我是微电子专业的,我需要去学习一门名为verilog的硬件解释语言,由于我是在某西部地区的神秘大学上学,这所…...
c++中sleep是什么意思(不是Sleep() )
sleep 函数在 C 语言中用于暂停程序执行指定的秒数,语法为 sleep(unsigned int seconds)。当 seconds 为 0 时,函数立即返回,否则函数将使进程暂停指定的秒数,并返回实际暂停的时间。 sleep 函数在 C 中的含义 sleep 函数是 C 标…...
Uniapp 开发中遇到的坑与注意事项:全面指南
文章目录 1. 引言Uniapp 简介开发中的常见问题本文的目标与结构 2. 环境配置与项目初始化环境配置问题解决方案 项目初始化注意事项解决方案 常见错误与解决方案 3. 页面与组件开发页面生命周期注意事项示例代码 组件通信与复用注意事项示例代码 样式与布局问题注意事项示例代码…...
Dify安装教程:Linux系统本地化安装部署Dify详细教程
1. 本地部署 Dify 应用开发平台 环境:Ubuntu(24.10) docker-ce docker compose 安装 克隆 Dify 源代码至本地环境: git clone https://github.com/langgenius/dify.git 启动 Dify: cd dify/docker cp .env.example...
rtsp rtmp 跟 http 区别
SDP 一SDP介绍 1. SDP的核心功能 会话描述:定义会话的名称、创建者、时间范围、连接地址等全局信息。媒体协商:明确媒体流的类型(如音频、视频)、传输协议(如RTP/UDP)、编码格式(如H.264、Op…...
基于YOLO11深度学习的运动鞋品牌检测与识别系统【python源码+Pyqt5界面+数据集+训练代码】
《------往期经典推荐------》 一、AI应用软件开发实战专栏【链接】 项目名称项目名称1.【人脸识别与管理系统开发】2.【车牌识别与自动收费管理系统开发】3.【手势识别系统开发】4.【人脸面部活体检测系统开发】5.【图片风格快速迁移软件开发】6.【人脸表表情识别系统】7.【…...
物体识别系统(识别图片中的物体)
这是一个基于 PyTorch 和 PyQt5 的物体识别程序,使用 Faster R-CNN 模型来识别图片中的物体,并通过图形界面展示识别结果。 1.用户界面 主窗口:包含加载图片、识别、清除按钮,以及图片显示区域和结果展示区域。 图片显示&#…...
数据表的存储过程和函数介绍
文章目录 一、概述二、创建存储过程三、在创建过程中使用变量四、光标的使用五、流程控制的使用六、查看和删除存储过程 一、概述 存储过程和函数是在数据库中定义的一些SQL语句的集合,然后直接调用这些存储过程和函数来执行已经定义好的SQL语句。存储过程和函数可…...
【DeepSeek-R1背后的技术】系列九:MLA(Multi-Head Latent Attention,多头潜在注意力)
【DeepSeek背后的技术】系列博文: 第1篇:混合专家模型(MoE) 第2篇:大模型知识蒸馏(Knowledge Distillation) 第3篇:强化学习(Reinforcement Learning, RL) 第…...
【JavaWeb12】数据交换与异步请求:JSON与Ajax的绝妙搭配是否塑造了Web的交互革命?
文章目录 🌍一. 数据交换--JSON❄️1. JSON介绍❄️2. JSON 快速入门❄️3. JSON 对象和字符串对象转换❄️4. JSON 在 java 中使用❄️5. 代码演示 🌍二. 异步请求--Ajax❄️1. 基本介绍❄️2. JavaScript 原生 Ajax 请求❄️3. JQuery 的 Ajax 请求 &a…...
[特殊字符] 蓝桥杯 Java B 组 之位运算(异或性质、二进制操作)
Day 6:位运算(异或性质、二进制操作) 📖 一、位运算简介 位运算是计算机底层优化的重要手段,利用二进制操作可以大大提高运算速度。常见的位运算包括: 与(&):a &am…...
[MDM 2024]Spatial-Temporal Large Language Model for Traffic Prediction
论文网址:[2401.10134] Spatial-Temporal Large Language Model for Traffic Prediction 论文代码:GitHub - ChenxiLiu-HNU/ST-LLM: Official implementation of the paper "Spatial-Temporal Large Language Model for Traffic Prediction" …...
LTO优化详解
嵌入式开发过程中的LTO优化是什么意思?能够用来解决什么问题?它都优化了哪些?仅开启LTO真的可以优化SIZE的问题吗? 请分别回答我刚才提到的问题? 嗯,用户问关于嵌入式开发中的LTO优化,我需要详细解释这个概…...
分布式事务三阶段协议
分布式事务的三阶段分别是准备阶段、预提交阶段和提交 / 回滚阶段,以下是详细介绍: 三阶段提交协议可以理解为两阶段提交协议的改良版,是在协调者和参与者中都引入超时机制,并且把两阶段提交协议的第一个阶段分成了两步: 询问&am…...
LLaMA-Factory|微调大语言模型初探索(4),64G显存微调13b模型
上篇文章记录了使用lora微调deepseek-7b,微调成功,但是微调llama3-8b显存爆炸,这次尝试使用qlora微调HQQ方式量化,微调更大参数体量的大语言模型,记录下来微调过程,仅供参考。 对过程不感兴趣的兄弟们可以直…...
常用高压缩率的视频容器格式,并进行大比例压缩
常用的高压缩率视频容器格式,包括*.mp4 、*.mkv、*.webM等。 容器格式本身并不直接决定压缩率,而是取决于容器中所使用的视频编码格式等因素。不过,在常见的视频容器格式中,一些容器在搭配特定编码格式时,通常能表现出较高的压缩效率,以下是相关介绍: 1 MKV格式 …...
代码编译(词法义)
1.预处理 (Preprocessing): 在这个阶段,编译器会处理所有以 # 开头的指令,如 #include、#define 等。它会把头文件的内容插入到源代码中,进行宏替换等预处理操作,生成一个纯净的代码文件。 3.词法分析 (Lexical Analy…...
android,flutter 混合开发,pigeon通信,传参
文章目录 app效果native和flutter通信的基础知识1. 编解码器 一致性和完整性,安全性,性能优化2. android代码3. dart代码 1. 创建flutter_module2.修改 Android 项目的 settings.gradle,添加 Flutter module3. 在 Android app 的 build.gradl…...
at32f403a rt thread led基础bsp工程测试
1.led工程官方bsp使用 导出一个独立的AT32F403A的BSP工程 下载RTT源代码 gitee更新较慢 https://gitee.com/rtthread/rt-thread github版本更新最新 https://github.com/RT-Thread/rt-thread. 切换到V5.1.0分支(使用一个发布版本可以避免不必要的bug) 导出一个独立的AT32BSP…...
SAP Webservice发布后,用SoapUI和Postman做接口测试的完整流程与参数调试技巧
SAP Webservice接口测试全攻略:SoapUI与Postman实战指南 当你在SAP系统中成功发布了Webservice或RESTful服务后,真正的挑战才刚刚开始。如何确保这些接口能够稳定、高效地与外部系统对接?本文将带你深入SoapUI和Postman这两款业界主流测试工具…...
前端调试进阶:除了‘禁用断点’,Chrome开发者工具里还有这些绕过debugger的冷门操作
前端调试进阶:Chrome开发者工具中绕过debugger的深度策略 调试是前端开发中不可或缺的一环,而debugger语句则是调试过程中最常见的工具之一。然而,在实际开发中,我们经常会遇到一些特殊情况:第三方库中故意设置的无限d…...
Git冲突实战:当IDEA/VSCode图形化界面失灵时,如何用纯命令‘救场’?
Git冲突实战:当IDE图形化界面失灵时,如何用纯命令‘救场’? 想象一下这样的场景:你在IntelliJ IDEA中点击了"Merge"按钮,却发现冲突文件中的标记混乱不堪,图形化界面突然变得难以操作。或者&…...
给 AI Agent 装上一双会看网页的眼睛:Dokobot Skill 体验
如果你最近也在折腾 AI agent,大概率会遇到一个很现实的问题: 很多 agent 看起来会“上网”,其实只是会发 HTTP 请求。 这在简单页面上问题不大,但一旦网页是前端渲染的,或者需要登录、滚动、交互,这种能…...
如何永久备份微信聊天记录:WeChatMsg完整免费工具终极指南
如何永久备份微信聊天记录:WeChatMsg完整免费工具终极指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/W…...
热搜第7!《灵魂摆渡》电影竟全AI生成,影视圈要变天了?
近日,一条关于经典国产网剧《灵魂摆渡》的消息悄然爬上微博热搜第7的位置,话题标签#灵魂摆渡电影全AI生成#”瞬间引爆了舆论场。对于许多资深剧迷而言,《灵魂摆渡》不仅是一部剧集,更是一段关于灵异、温情与人生哲理的青春记忆。然…...
CCC数字钥匙车主配对【NFC】——Phase2安全通道与证书交换详解
1. CCC数字钥匙车主配对Phase2的核心价值 想象一下这样的场景:你刚买了一辆新车,掏出手机轻轻一碰车门把手,车辆就自动解锁并启动引擎。这背后最关键的技术环节,就是CCC数字钥匙的车主配对流程。而Phase2阶段,正是整个…...
3分钟搞定B站字幕提取:告别手动抄写的烦恼
3分钟搞定B站字幕提取:告别手动抄写的烦恼 【免费下载链接】BiliBiliCCSubtitle 一个用于下载B站(哔哩哔哩)CC字幕及转换的工具; 项目地址: https://gitcode.com/gh_mirrors/bi/BiliBiliCCSubtitle 还在为B站视频里的精彩内容无法保存而烦恼吗?&a…...
@开源人,百万激励池!第八届CCF开源创新大赛等你来战!
8年,可以见证一项 技术 从萌芽走向成熟的跨越; 8年,也可以让一项赛事从崭露头角成长为业内公认的标杆。 在开源与数字科技领域,这8年更是意义非凡 ——开源技术正以前所未有的速度重构产业生态,成为智能时代不可或缺的…...
别再混淆SNR和Eb/N0了!用Wi-Fi 6(802.11ax)实测数据讲透数字通信核心指标
从Wi-Fi 6实测数据透视数字通信核心指标:SNR与Eb/N0的本质差异 在调试一台支持Wi-Fi 6的路由器时,工程师小张发现了一个奇怪现象:当信号强度显示为-65dBm时,实测吞吐量在不同频段竟相差30%。这个案例揭示了通信系统中一个关键认知…...
