【题目】
给定一个数组,将数组中的元素向右移动 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]
【答案】
class Solution {
public:
void rotate(vector<int>& nums, int k) {
int n=nums.size();
vector<int> a(n);//注意在定义时需要确定个数,且<int>也需注意
for(int i=0;i<n;i++)
a[(i+k)%n]=nums[i];//注意脚标变化通式
nums.assign(a.begin(),a.end());
}
};
总结:
1.利用两个向量
2.脚标变化通式:(i+n)/k