要扩展数组逆序函数使其支持自定义比较函数,可以使用函数指针来实现。首先,定义一个函数指针类型来表示比较函数的类型,然后在逆序函数中接受一个比较函数作为参数。以下是一个示例代码:
#include <stdio.h>
typedef int (*compare_func)(int, int);
void reverse_array(int arr[], int size, compare_func comp) {
int start = 0;
int end = size - 1;
while (start < end) {
int temp = arr[start];
arr[start] = arr[end];
arr[end] = temp;
start++;
end--;
}
}
int compare_asc(int a, int b) {
return a - b;
}
int compare_desc(int a, int b) {
return b - a;
}
int main() {
int arr[] = {1, 2, 3, 4, 5};
int size = sizeof(arr) / sizeof(arr[0]);
reverse_array(arr, size, compare_asc);
printf("Array in ascending order: ");
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
printf("\n");
reverse_array(arr, size, compare_desc);
printf("Array in descending order: ");
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
在上面的示例中,reverse_array
函数接受一个比较函数 comp
作为参数,这样就可以根据不同的比较函数实现不同的逆序效果。在 main
函数中,我们定义了两个比较函数 compare_asc
和 compare_desc
分别用于升序和降序排列数组。通过传递不同的比较函数给 reverse_array
函数,我们可以实现不同的逆序效果。