#include "stdio.h"
#include "stdlib.h"
#include "string.h"
//打印字符串内容
int PrintStr13(char ** Array, int n) {//第一种和第三种方式
int i = 0;
for(i = 0; i < n; i++) {
printf("%s\n",Array[i]);
}
return 0;
}
int PrintStr2(char Array[][30], int n) {//第二种方式char (*Array)[30]
int i = 0;
for(i = 0; i < n; i++) {
printf("%s\n",Array[i]);
}
return 0;
}
//字符串排序
int SortStr13(char ** Array, int n) {//第一种和第三种方式
int i = 0, j = 0;
char *temp;
for(i = 0; i < n; i++) {
for(j = i; j < n; j++) {
if(Array[i] > Array[j]) {
temp = Array[i];
Array[i] = Array[j];
Array[j] = temp;
}
}
}
return 0;
}
int SortStr2(char Array[][30], int n) {//第二种方式
int i = 0, j = 0;
char temp[30];
for(i = 0; i < n; i++) {
for(j = i; j < n; j++) {
if(strcmp(Array[i],Array[j]) > 0) {
strcpy(temp,Array[i]);
strcpy(Array[i],Array[j]);
strcpy(Array[j],temp);
}
}
}
return 0;
}
int main()
{
int i = 0;
char *ArrayStr1[] = {"ccc","bbb","ddd","aaa"};//第一种输入
char ArrayStr2[][30] = {"ccc","bbb","ddd","aaa"};//第二种输入
char **ArrayStr3 = (char **)malloc(10*sizeof(char *));//第三种输入
for(i = 0; i < 10; i++) {
ArrayStr3[i] = (char *)malloc(100*sizeof(char));
sprintf(ArrayStr3[i],"%d%d%d",i,i,i);
}
//第一种二级指针接口
printf("第一种排序之前\n");
PrintStr13(ArrayStr1,4);
SortStr13(ArrayStr1,4);
printf("第一种排序之后\n");
PrintStr13(ArrayStr1,4);
//第二种二级指针接口
printf("第二种排序之前\n");
PrintStr2(ArrayStr2,4);
SortStr2(ArrayStr2,4);
printf("第二种排序之后\n");
PrintStr2(ArrayStr2,4);
//第三种二级指针接口
printf("第三种排序之前\n");
PrintStr13(ArrayStr3,4);
SortStr13(ArrayStr3,4);
printf("第三种排序之后\n");
PrintStr13(ArrayStr3,4);
//释放malloc的内存
for(i = 0; i < 10; i++) {
if(ArrayStr3[i] != NULL)
free(ArrayStr3[i]);
}
if(ArrayStr3 != NULL)
free(ArrayStr3);
return 0;
}