当前位置: 首页 > news >正文

【Hot 100 刷题计划】 LeetCode 189. 轮转数组 | C++ 三次反转经典魔法 (O(1) 空间)

LeetCode 189. 轮转数组

📌 题目描述

题目级别:中等

给定一个整数数组nums,将数组中的元素向右轮转k个位置,其中k是非负数。

进阶要求:
尽可能想出更多的解决方案,至少有三种不同的方法可以解决这个问题。
你可以使用空间复杂度为O(1)原地算法解决这个问题吗?

  • 示例 1:
    输入:nums = [1,2,3,4,5,6,7], k = 3
    输出:[5,6,7,1,2,3,4]

💡 破题思路:三次反转 (数组魔术)

最容易想到的办法是开辟一个新数组,把后面的元素搬到前面,前面的搬到后面。但这会消耗 O(N) 的额外空间。
要想实现 O(1) 空间复杂度的“原地”轮转,最经典的解法就是**“三次反转法”**。

这就像是一个精妙的数学魔术。以nums = [1,2,3,4,5,6,7],k = 3为例,我们需要把最后 3 个元素搬到最前面。
按照本解法的独家顺序:

  1. 反转前半段:把前n-k个元素反转。[1,2,3,4]变成了[4,3,2,1]
    此时数组:[4,3,2,1, 5,6,7]
  2. 反转后半段:把最后k个元素反转。[5,6,7]变成了[7,6,5]
    此时数组:[4,3,2,1, 7,6,5]
  3. 整体反转:把整个数组头尾对调!前面的去了后面,后面的来了前面,而且之前内部被打乱的顺序,在这一次整体反转中负负得正,完美还原
    最终数组:[5,6,7, 1,2,3,4]

⚠️ 极客避坑点
如果k的值比数组长度n还要大,比如数组长度为 7,让你轮转 10 次,其实就等价于轮转了10 % 7 = 3次。所以第一步必须进行取模运算k = k % n


💻 C++ 代码实现

classSolution{public:voidrotate(vector<int>&nums,intk){intn=nums.size();// 核心细节:剥除多余的整圈轮转k=k%n;// 第一步:反转前半部分 (前 n-k 个元素)reverse(nums.begin(),nums.end()-k);// 第二步:反转后半部分 (后 k 个元素)reverse(nums.end()-k,nums.end());// 第三步:整体反转,首尾对调完成最终轮转reverse(nums.begin(),nums.end());}};
http://www.jsqmd.com/news/722026/

相关文章:

  • Prism模块懒加载实战:让你的WPF应用启动速度飞起来
  • 作为开源ClaudeCoWork!别再把 AI 当聊天框了,OpenCowork 让它真正「会干活」
  • SHAP值统计显著性检验:如何科学验证特征重要性的可靠性?
  • PowerToys中文完整汉化版:如何免费解锁Windows终极效率工具集?
  • OnStep完整指南:用开源控制器打造你的智能天文望远镜系统
  • Agent RAG:2026企业AI的决定性赛道
  • 【Hot 100 刷题计划】 LeetCode 15. 三数之和 | C++ 排序+双指针
  • Claude Opus 4.7、GPT-5.5 与 DeepSeek-V4-Pro 对比分析
  • 2026年q2重庆地区废铁金属回收公司排行盘点:重庆废旧机械设备回收,重庆废钢金属回收,排行一览! - 优质品牌商家
  • 别再让Win10虚拟机卡成PPT!这18个保姆级优化设置,让你的VMware/VirtualBox飞起来
  • 如何在DbGate中快速连接MySQL数据库:完整配置指南与实用技巧
  • PPTist终极指南:三步掌握免费在线PPT制作,告别PowerPoint依赖
  • Windows字体渲染革命:5分钟掌握MacType终极配置技巧
  • 从论文模板到实战:手把手教你用TeXstudio配置中文写作环境(XeLaTeX + UTF-8)
  • 磨削电主轴热误差预测与故障机理【附代码】
  • 避坑指南:Keil uVision5新建工程到生成HEX文件的完整流程(含常见报错解决)
  • 避坑指南:手把手教你用Python 3.7和PyTorch 1.12.1搞定SAGA(CVPR 2023)3D点云分割环境配置
  • JBoltAI V4.3发布:AgentRAG让企业AI真正
  • Spring Cloud项目日志改造实战:从logback迁移到log4j2,顺便搞定异步线程TraceId丢失的坑
  • Cursor Pro破解工具终极指南:一键激活AI编程助手永久免费使用教程
  • 从门禁卡到5G通信:国密算法SM1/SM4/SM7/ZUC在你身边的隐藏应用图鉴
  • 如何永久保存微信聊天记录:WeChatMsg终极指南
  • 从零准备校招编程面试,保姆级路线图
  • Hot 100 刷题计划】 LeetCode 146. LRU 缓存 | C++ 哈希表+双向链表
  • 流浪动物救助小程序(文档+源码)_kaic
  • 终极GModPatchTool指南:3步彻底修复Garry‘s Mod浏览器功能异常
  • Linux学习日常13
  • 2026年q2国内冷弯型钢设备主流品牌实测排行:c型钢冷弯设备,u型钢辊压成型机,光伏支架冷弯设备,优选指南! - 优质品牌商家
  • 从CU/DU分离到8种Option:手把手拆解5G基站(gNB)内部架构与接口选择
  • 不止于开发:用mkcert为你的家庭NAS、智能家居搭建安全HTTPS内网访问