c语言

C语言怎么扩展数组逆序函数使其支持自定义比较函数

小亿
83
2024-05-27 10:10:14
栏目: 编程语言

要扩展数组逆序函数使其支持自定义比较函数,可以使用函数指针来实现。首先,定义一个函数指针类型来表示比较函数的类型,然后在逆序函数中接受一个比较函数作为参数。以下是一个示例代码:

#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_asccompare_desc 分别用于升序和降序排列数组。通过传递不同的比较函数给 reverse_array 函数,我们可以实现不同的逆序效果。

0
看了该问题的人还看了