可以通過創建一個新的數組來存放逆序的元素,而不改變原數組。以下是一個示例代碼:
#include <stdio.h>
int* reverseArray(int arr[], int size) {
int* reversedArr = (int*)malloc(size * sizeof(int));
for (int i = 0; i < size; i++) {
reversedArr[i] = arr[size - 1 - i];
}
return reversedArr;
}
int main() {
int arr[] = {1, 2, 3, 4, 5};
int size = sizeof(arr) / sizeof(arr[0]);
int* reversedArr = reverseArray(arr, size);
for (int i = 0; i < size; i++) {
printf("%d ", reversedArr[i]);
}
free(reversedArr);
return 0;
}
在這個示例中,reverseArray
函數接受一個整型數組和數組大小作為參數,然后創建一個新的數組 reversedArr
來存放逆序的元素,最后返回這個新數組。在 main
函數中,我們可以通過調用 reverseArray
函數來獲取逆序的數組,并打印出來。最后記得釋放 reversedArr
的內存空間。