给定一个整数数组 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 - 10 <= k <= 105题意挺好理解,就是将一个数组循环右移嘛。如果能够使用一个额外的数组,那将是非常容易,将数据拷贝一份,然后依次拷贝到偏移下标的地方,但是如果要求O(1)的空间复杂度呢?也是不难想起来,比如示例一,从下标0开始,依次将下标0的元素挪到下标3,即1挪到4的位置,以此类推,4挪到7的位置……,但是点子易得,方案难想,因为里面有许多细节需要确定。比如就这样挪动下去,截至条件是啥呢?一个很自然的想法是对挪动次数计数,截止条件就是计数值等于数组长度,我当时就是这么想得,可是这不是全部的真相。比如举个简单的例子,数组为
...
继续阅读
(68)