C语言在主函数中输入 10 个等长的字符串。自定义一个函数对这 10 个字符串进行升序排序, 在主函数中调用此函数并输出排序好的字符串。 【设计要求】 (1)用二维数组作为自定义函数函数的数据类型; (2)使用冒泡排序对字符进行升序排序; (3)在主函数中输入 10 个等长的字符串,存储在一个二维数组中,以这个二维数组的 数组名作为实参进行地址传递调用自定义函数; (4)在主函数中输出排序后的结果
时间: 2023-06-25 14:02:26 浏览: 117
以下是代码实现:
```c
#include <stdio.h>
#include <string.h>
void bubbleSort(char arr[][100], int n) {
int i, j;
char temp[100];
for(i = 0; i < n-1; i++) {
for(j = 0; j < n-i-1; j++) {
if(strcmp(arr[j], arr[j+1]) > 0) {
strcpy(temp, arr[j]);
strcpy(arr[j], arr[j+1]);
strcpy(arr[j+1], temp);
}
}
}
}
int main() {
char str[10][100];
int i, n = 10;
printf("Enter 10 strings of equal length:\n");
for(i = 0; i < n; i++) {
scanf("%s", str[i]);
}
bubbleSort(str, n);
printf("\nSorted strings are:\n");
for(i = 0; i < n; i++) {
printf("%s\n", str[i]);
}
return 0;
}
```
在这个程序中,我们首先定义了一个 `bubbleSort` 函数,该函数采用冒泡排序算法对字符串数组进行升序排序。然后,在 `main` 函数中,我们声明了一个二维字符数组 `str`,并要求用户输入 10 个等长的字符串。接下来,我们将该数组作为地址传递给 `bubbleSort` 函数,并在排序后输出排好序的字符串数组。
阅读全文