给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数。 复制代码
示例:
输入: [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] 输入: [-1,-100,3,99] 和 k = 2 输出: [3,99,-1,-100] 解释: 向右旋转 1 步: [99,-1,-100,3] 向右旋转 2 步: [3,99,-1,-100] 复制代码
思考:
这道题有一种巧妙地利用反转的做法。 首先将第0个到第k个元素反转,再将第k+1到末尾元素反转,最后再将全部元素反转即可。 例如:[1,2,3,4,5,6,7] k = 3 将0到3反转:[4,3,2,1,5,6,7] 将4到6反转:[4,3,2,1,7,6,5] 全部翻转:[5,6,7,1,2,3,4] 得到最后结果。 这里要注意下还有这样的情况:[1,2] k = 5 即k大于数组长度的情况。 这里可以发现数组旋转次数等于数组长度时,旋转后的数组与初始数组相同,转了一圈又回来了。 1次旋转:[2,1] 2次旋转: [1,2] 转回来了 3次旋转:[2,1] 4次旋转: [1,2] 转回来了 5次旋转:[2,1] 所以这里的有效k等于k对数组长度求余。 复制代码
实现:
class Solution {
public void rotate(int[] nums, int k) {
int length = nums.length;
k %= length;
reverse(nums, 0, length - 1);
reverse(nums, 0, k - 1);
reverse(nums, k, length - 1);
}
private void reverse(int[] nums, int start, int end) {
while (start < end) {
int temp = nums[start];
nums[start++] = nums[end];
nums[end--] = temp;
}
}
}复制代码
以上所述就是小编给大家介绍的《LeetCode每日一题: 旋转数组(No.189)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
产品经理手册(原书第4版)(白金版)
[美] 琳达·哥乔斯(Linda Gorchels) / 祝亚雄、冯华丽、金骆彬 / 机械工业出版社 / 2017-8 / 65.00
产品经理的职责起点是新产品开发,贯穿产品生命周期的全过程。本书按上下游产品管理进行组织。 在上游的新产品开发流程中,作者阐述了如何从市场、产品、行业、公司的角度规划企划方案,并获得老板、销售部、运营部的资源支持,推进新产品的项目流程,实现所有目标,制定和实施新产品发布。 下游产品的管理核心在于生命周期的管理,营销更是生命周期管理的重中之重。产品经理如何让产品满足客户需求,让客户获得对产......一起来看看 《产品经理手册(原书第4版)(白金版)》 这本书的介绍吧!