c语言中如何用指针对二维数组每一行进行排序
时间: 2024-04-14 15:27:50 浏览: 143
在C语言中,可以使用指针对二维数组的每一行进行排序。以下是一个示例代码:
```c
#include <stdio.h>
// 交换两个整数的值
void swap(int *a, int *b) {
int temp = *a;
*a = *b;
*b = temp;
}
// 对二维数组的每一行进行排序
void sortRows(int (*arr)[5], int rows) {
for (int i = 0; i < rows; i++) {
// 冒泡排序
for (int j = 0; j < 5 - 1; j++) {
for (int k = 0; k < 5 - j - 1; k++) {
if (arr[i][k] > arr[i][k+1]) {
swap(&arr[i][k], &arr[i][k+1]);
}
}
}
}
}
int main() {
int arr[3][5] = { {9, 5, 2, 7, 1}, {6, 4, 8, 3, 0}, {12, 10, 11, 15, 13} };
sortRows(arr, 3);
printf("Sorted array:\n");
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 5; j++) {
printf("%d ", arr[i][j]);
}
printf("\n");
}
return 0;
}
```
上述代码中,我们使用了一个 `swap` 函数来交换两个整数的值。然后,我们通过 `sortRows` 函数对二维数组的每一行进行排序。在 `main` 函数中,我们定义了一个具有3行5列的二维数组,然后调用 `sortRows` 函数对其进行排序,并打印排序后的结果。
输出结果将是:
```
Sorted array:
1 2 5 7 9
0 3 4 6 8
10 11 12 13 15
```
这里我们使用了冒泡排序算法,你也可以根据需要选择其他排序算法来对二维数组的每一行进行排序。
阅读全文