算法思想:先将需要反转的数组的那部分分别反转,最后再将整个数组反转,即可实现数组中相邻两段位置的互换。
例如:1 2 3 4 5 6 7 我想把1234,和567的位置交换,则先将1234反转为4321,再将567反转为765,得到4 3 2 1 7 6 5 最后将整个数组反转得到5 6 7 1 2 3 4。
伪代码如下:
//这个函数使用的是计数方法从1开始算,主函数中不需要执行此函数,直接执行Change函数即可
void Reverse(int arr[],int left,int right) {
int count=(right - left) / 2+1;
for (int i = 0; i < count; i++)
{
int temp;
temp = arr[i + left];
arr[i + left] = arr[right - i];
arr[right - i] = temp;
}
}
//这个函数使用的是下标从0开始算
void Change(int arr[], int left_arr_begin_index, int right_arr_begin_index,int arr_size) {
Reverse(arr,left_arr_begin_index,right_arr_begin_index-1);
Reverse(arr, right_arr_begin_index, arr_size - 1);
Reverse(arr, 0, arr_size - 1);
}