输入3个字符串(字符串大小不超过80个字符),按由小到大的顺序输出。 要求:用函数处理,且用指针做函数参数,实现交换两个字符串:void swap(char *p1,char *p2)。
时间: 2024-12-22 19:12:25 浏览: 5
为了实现这个功能,你可以创建一个名为`sortStrings`的函数,接收三个字符串的指针作为输入,并按照字典序对它们进行排序。这里我们假设`swap`函数已经存在,用于交换两个字符串:
```c
#include <stdio.h>
#include <string.h>
// 已经存在的函数,用于交换两个字符串
void swap(char* p1, char* p2) {
char temp[81];
strcpy(temp, p1);
strcpy(p1, p2);
strcpy(p2, temp);
}
// 按字典序从小到大排序并输出
void sortStrings(char** strings, int count) {
for (int i = 0; i < count - 1; i++) {
for (int j = 0; j < count - i - 1; j++) {
if (strcmp(strings[j], strings[j + 1]) > 0) {
// 使用swap函数交换字符串
swap(strings+j, strings+j+1);
}
}
}
// 输出排序后的字符串数组
for (int i = 0; i < count; i++) {
printf("%s ", strings[i]);
}
printf("\n");
}
int main() {
char* str1 = "hello";
char* str2 = "world";
char* str3 = "test";
char* stringArray[] = {str1, str2, str3};
int numStrings = sizeof(stringArray) / sizeof(*stringArray);
sortStrings(stringArray, numStrings);
return 0;
}
```
在这个例子中,`sortStrings`函数首先通过嵌套循环比较相邻的字符串,如果前者的字典序大于后者,则调用`swap`函数交换它们的位置。最后,函数会遍历排序后的字符串数组并输出。
阅读全文