code算法
void reverse(int array[], int left, int right) { int l, r; for (l = left, r = right; l < r; l++, r--) { array[l] = array[l] ^ array[r]; array[r] = array[l] ^ array[r]; // l ^ r ^ r = l ^ 0 = l. array[l] = array[l] ^ array[r]; // l ^ r ^ l = r ^ 0 = r; } }
上述代码经过异或运算来高效实现变量值的交换,请记住:数组
假设咱们循环左移n位,则实现的步骤是:code
以上步骤的顺序也能够改成step2 -> step1 -> step3.class
code:变量
reverse(array, 0, left_shift_num - 1); reverse(array, left_shift_num, array_size - 1); reverse(array, 0, array_size - 1);
假设咱们循环右移n位,则实现的步骤是:循环
以上步骤的顺序也能够改成step2 -> step1 -> step3.co
code:void
reverse(array, 0, array_size - right_shift_num - 1); reverse(array, array_size - right_shift_num, array_size - 1); reverse(array, 0, array_size -1);