在C语言中,我们可以使用qsort函数来进行排序。为了实现按照绝对值升序排列数组,我们需要定义一个比较函数,并在函数中使用abs()函数来计算绝对值。
以下是示例代码:
#include
#include
#include
int compare(const void *a, const void *b) {
int num1 = abs(*(int*)a);
int num2 = abs(*(int*)b);
if (num1 < num2)
return -1;
if (num1 > num2)
return 1;
return 0;
}
int main() {
int arr[] = {2, -3, 4, -1, 6, -7};
int n = sizeof(arr) / sizeof(arr[0]);
qsort(arr, n, sizeof(int), compare);
printf("Sorted array by absolute value: ");
for (int i = 0; i < n; i++)
printf("%d ", arr[i]);
return 0;
}
在上面的代码中,我们首先定义了一个比较函数“compare”,该函数的参数包括两个指针a和b,指向需要比较的两个整数。在函数中,我们使用abs()函数计算整数的绝对值,然后根据绝对值的大小来比较两个整数的大小。最后,我们在主函数中调用qsort函数来对数组进行排序,并打印排序后的结果。
该示例代码的输出结果为:
Sorted array by absolute value: 1 2 -3 4 6 -7
可以看到,数组已按绝对值的升序排列,并按实际值显示。
上一篇:按绝对值排序范围