要实现数组逆序但保持某些元素的相对位置不变,可以先将需要保持位置不变的元素暂时保存起来,然后对除这些元素以外的元素进行逆序操作,最后再将保存的元素按原顺序放回数组中。
以下是一个示例代码实现:
#includevoid reverseArray(int arr[], int start, int end) { while (start < end) { int temp = arr[start]; arr[start] = arr[end]; arr[end] = temp; start++; end--; } } void reverseArrayAndKeepElements(int arr[], int size, int keep[], int keepSize) { // 保存需要保持位置不变的元素 int temp[size]; for (int i = 0; i < size; i++) { temp[i] = arr[i]; } // 对数组进行逆序操作 reverseArray(arr, 0, size - 1); // 将保持位置不变的元素放回数组中 for (int i = 0; i < keepSize; i++) { int index = -1; for (int j = 0; j < size; j++) { if (temp[j] == keep[i]) { index = j; break; } } if (index != -1) { arr[index] = keep[i]; } } } int main() { int arr[] = {1, 2, 3, 4, 5, 6}; int keep[] = {2, 3, 4}; int size = sizeof(arr) / sizeof(arr[0]); int keepSize = sizeof(keep) / sizeof(keep[0]); reverseArrayAndKeepElements(arr, size, keep, keepSize); for (int i = 0; i < size; i++) { printf("%d ", arr[i]); } return 0; }
在这个示例代码中,我们定义了一个reverseArrayAndKeepElements
函数来实现数组逆序但保持某些元素的相对位置不变的功能。在main
函数中,我们定义了一个数组arr
,并定义了一个需要保持位置不变的元素数组keep
,然后调用reverseArrayAndKeepElements
函数进行操作。最终输出逆序后的数组。