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

轮转数组-leetcode

题目描述

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

示例 1:

输入: nums = [1,2,3,4,5,6,7], k = 3
输出: [5,6,7,1,2,3,4]
解释:
向右轮转 1 步: [7,1,2,3,4,5,6]
向右轮转 2 步: [6,7,1,2,3,4,5]
向右轮转 3 步: [5,6,7,1,2,3,4]

示例 2:

输入:nums = [-1,-100,3,99], k = 2
输出:[3,99,-1,-100]
解释: 
向右轮转 1 步: [99,-1,-100,3]
向右轮转 2 步: [3,99,-1,-100]

提示:

  • 1 <= nums.length <= 105
  • -231 <= nums[i] <= 231 - 1
  • 0 <= k <= 105

进阶:

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

解法一

思路:

环形替换,防止前面的数字覆盖,从后向前循环,循环开头的时候,开头元素已经被更改了,所以我们采用一个数组记录原始开头的几个数,然后再对这几个数字填充到正确的地方。

代码:

class Solution {public void rotate(int[] nums, int k) {int numsLen=nums.length;if(numsLen==1) return;int tempLen=k%nums.length;int[] temp=new int[tempLen];for(int i=0;i<tempLen;i++){temp[i]=nums[i];}for(int i=numsLen-1;i>=tempLen;i--){nums[(i+tempLen)%numsLen]=nums[i];}int cnt=0;for(int i=tempLen;i<2*tempLen;i++){nums[i%numsLen]=temp[cnt++];}}
}
http://www.rkmt.cn/news/7544.html

相关文章:

  • CF1864G Magic Square
  • OI TRICKS
  • 深入解析:Okular开源免费的跨平台文档查看神器
  • day37大模型程序开发-GraphRAG理论
  • day10-AI短视频01
  • 【每日算法】两数相加 LeetCode - 教程
  • MacCAD2019.dmg 安装包使用教程|Mac电脑安装CAD2019全流程
  • 初始化一个rust环境
  • 编程里边有好多不容易触及的知识点
  • PostgreSQL repmgr 高可用之故障转移
  • 25.9.18随笔联考总结
  • P3642 [APIO2016] 烟花表演 解题报告
  • Slope Trick 学习笔记
  • sql server 折腾时不小心去掉了 sysadmin 权限
  • 题解:P13882 [蓝桥杯 2023 省 Java A] 小蓝的旅行计划
  • 深入解析:无人设备遥控器之帧同步技术篇
  • 更快的布尔矩阵乘法
  • 干货预警!Apache SeaTunnel 助力多点 DMALL 构建数据集成平台,探索AI新零售行业应用!
  • 安全认证哪家强?CISP和HCIE我选...... - 详解
  • 小学生模拟赛题解
  • LLM大模型:Qwen3-Next-80B中的next究竟是个啥?
  • K8s 必备:kubectl patch 命令详解
  • 深入解析:AI Ping:精准可靠的大模型服务性能评测平台
  • 从0打造一个TTS语音合成引擎:原理与实现
  • 实用指南:基于边缘计算的智能管控终端充电站有序充电系统设计与实现 —— 面向实时功率调度需求
  • 丘成桐谈AI
  • 人小鼠免疫细胞maker基因 - un
  • 国标GB28181视频平台EasyGBS如何解决安防视频融合与级联管理的核心痛点?
  • 人 CD 抗原完全指南 - un
  • 从ppm到ppb:全面解读浓度单位转换的诀窍 - 实践