- 轮转数组 中等
给你一个数组,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。
输入: 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]
class Solution {
public void rotate(int[] nums, int k) {
k %= nums.length;
/位移的长度超过数组的长度处理
reverse(nums, 0, nums.length - 1);
reverse(nums, 0, k - 1);
reverse(nums, k, nums.length - 1);
}public void reverse(int[] nums, int start, int end) {
while (start < end) {
int temp = nums[start];
nums[start] = nums[end];
nums[end] = temp;
start += 1;
end -= 1;
}
}
}
组件 【算法|字节 常见算法题】
推荐阅读
- C语言|初级指针详解
- 智能优化算法|智能优化算法(冠状病毒群体免疫优化算法 -附代码)
- 智能优化算法|智能优化算法1-冠状病毒群免疫优化算法(CHIO)
- 数学建模|数学建模(线性回归模型)
- 算法|工程师如何解决穿衣搭配烦恼(——滴搭平台与算法)
- 资讯|算法工程师日均写 7 行代码被开除,法院判决公司赔偿 3.6 万元
- 人工智能|人类越来越懒是技术进步的根源!
- 算法|MPC入门与Matlab实现
- 机器学习|基于流的(Flow-based)生成模型简介