定义函数实现字符串排序 函数接口定义: void fun(char* str[],int n) str是存储n个字符串首地址的指针数组,n是字符串个数 裁判测试程序样例: #include <stdio.h> #include <string.h> #include <stdlib.h> void fun(char* str[],int n); main() { int i,n; char *strn[10],t[20]; scanf("%d",&n); for(i=0;i<n;i++) { scanf("%s",t); strn[i]=(char*)malloc(strlen(t)+1); strcpy(strn[i],t); } fun(strn,n); for(i=0;i<n;i++) printf("%s",strn[i]); } @@@ /* 请在这里填写答案 */
时间: 2024-03-25 22:39:50 浏览: 153
根据题目要求,我们需要实现一个函数 `fun`,它的输入参数是一个字符串指针数组 `str` 和一个整数 `n`,表示字符串的个数。函数的作用是将字符串按字典序排序。
下面是一个示例代码:
```c
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
void fun(char* str[], int n);
int main()
{
int i, n;
char *strn[10], t[20];
scanf("%d", &n);
for (i = 0; i < n; i++) {
scanf("%s", t);
strn[i] = (char*)malloc(strlen(t) + 1);
strcpy(strn[i], t);
}
fun(strn, n);
for (i = 0; i < n; i++) {
printf("%s", strn[i]);
}
return 0;
}
void fun(char* str[], int n)
{
int i, j;
char *temp;
for (i = 0; i < n - 1; i++) {
for (j = i + 1; j < n; j++) {
if (strcmp(str[i], str[j]) > 0) {
temp = str[i];
str[i] = str[j];
str[j] = temp;
}
}
}
}
```
在主函数中,我们先读入整数 `n` 和字符串数组 `strn`,然后利用 `malloc` 函数为每个字符串动态分配内存,并将其存储到 `strn` 数组中。
接下来,我们调用函数 `fun` 对字符串进行排序。在排序过程中,我们使用了 `strcmp` 函数来比较字符串的大小,并使用了指针变量 `temp` 来交换字符串的位置。
最后,我们在主函数中输出排序后的字符串数组。
希望这个示例代码能够解决你的问题。如果你还有其他问题,可以继续提出。
阅读全文