in place交換
如果是k步,那么就是把后面k個放到前面了嘛。
我們先把整個數組reverse,然后把前面的reverse回來,再把后面的reverse回來
對於AB我們要通過reverse操作得到BA
那么先把AB reverse一次得到reverse(B)reverse(A)
然后再把reverse(B),reverse(A)分別reverse一次就得到了BA
class Solution { public: void rotate(int nums[], int n, int k) { k = k % n; reverse(nums, nums + n); reverse(nums, nums + k); reverse(nums + k, nums + n); } };