C语言怎么扩展数组逆序函数使其支持自定义比较函数
导读:要扩展数组逆序函数使其支持自定义比较函数,可以使用函数指针来实现。首先,定义一个函数指针类型来表示比较函数的类型,然后在逆序函数中接受一个比较函数作为参数。以下是一个示例代码: #include <stdio.h> typed...
要扩展数组逆序函数使其支持自定义比较函数,可以使用函数指针来实现。首先,定义一个函数指针类型来表示比较函数的类型,然后在逆序函数中接受一个比较函数作为参数。以下是一个示例代码:
#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
函数,我们可以实现不同的逆序效果。
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: C语言怎么扩展数组逆序函数使其支持自定义比较函数
本文地址: https://pptw.com/jishu/678436.html