灼灼桃花,三千繁华,却似人间只有一个他。
#include<stdio.h>
#include<string.h>
void sk(char **pi, int m);
int main(void)
{
int i, n;
char **p, *q[50], a[50][100];
scanf("%d",&n);
// 输入字符串个数
for(i = 0; i < 50; i++)
q[i] = a [i];
// q指针指向a数组
printf("输入字符串:\n");
for(i = 0; i < n; i++)
gets(q[i]);
// scanf("%s",q[i]);
// 利用gets输入字符串, 如果用sacnf,则需小心空格会使字符串中止
p = q;
// 二级指针p指向q
sk(p, n);
// 调用函数
printf("输出字符串:");
for (i = 0; i < n; i++)
printf("%s\n",q[i]);
// 输出字符串
return 0;
}
void sk(char **pi, int m)
//利用选择排序对字符串进行排序
{
int i, j;
char max;
for (i = 0; i < m; i++){
max = **(pi + i);
// 将该次循环的第一个标记为max
for(j = i; j <m; j ++){
if (strcmp(*(pi + j), * (pi + i))> 0)
max = **(pi +j);
// 将最大的的字符串赋值给max
}
**(pi + i ) = max;
// 将max的值返回给该次循环的第一个数,完成排序
}
}