要扩展数组逆序函数使其支持自定义比较函数,可以使用函数指针来实现。首先,定义一个函数指针类型来表示比较函数的类型,然后在逆序函数中接受一个比较函数作为参数。以下是一个示例代码:
#includetypedef 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
函数,我们可以实现不同的逆序效果。