https://blog.csdn.net/bbs375/article/details/52537521
第一种:指针数组
char* myArr[4]={“ddd”,”cccc”,”bbbb”,”aaaaaaa”};
调用:sort_arr(myArr,4);
void sortMyArray11(char **myArray, int num)
{
int i =0 , j = 0;
char *tmp = NULL;
//排序
for (i=0; i<num; i++)
{
for (j=i; j<num; j++)
{
if (strcmp(myArray[i], myArray[j]) > 0 )
{
tmp = myArray[i]; //注意 交换的是数组元素 交换的是指针的值 //改变指针的指向
myArray[i] = myArray[j];
myArray[j] = tmp;
}
}
}
}
第二种:二维数组
char myArr[10][20]={“ff”,”bbbbb”,”ddddd”,”ccccc”,”eeeee”};
调用:sort_arr(myArr,num);
//交换的是内存块。。。。。。。。
void sortMyArray02(char myArray[10][30], int num)
{
int i, j = 0;
char tmpBuf[30];
for (i=0; i<num; i++)
{
for (j=i+1; j<num; j++)
{
if (strcmp (myArray[i], myArray[j]) > 0)
{
strcpy(tmpBuf, myArray[i]); //交换的是内存块
strcpy(myArray[i], myArray[j]);
strcpy(myArray[j], tmpBuf);
}
}
}
}
第三种:二级指针
char **p = NULL;
调用:getMen2(&p,5); //n级指针修改n-1级的值
//问题的本质是: 第2种内存模型 的 myArray + 1 与第1种内存模型 myArray + 1 不一样 ;//指针的步长不一样 指针所指向的内存空间的数据类不一样 。。。。
三种二级指针的内存模型:
//二级指针做输入的三种内存模型
//第一种
void printArray1(char** array,int cnt)
{
int i;
for (i = 0; i < cnt; i++)
{
printf("%s ",array[i]);
}
printf("\n");
}
void sortArray1(char**array, int cnt)
{
int i, j;
char *tmp=NULL;
for (i = 0; i < cnt; i++)
{
for (j = i; j < cnt; j++)
{
if (strcmp(array[i],array[j])>0)
{
tmp = array[i];
array[i] = array[j];
array[j] = tmp;
}
}
}
}
int main1()
{
char *myArray[] = {"wwwwwww","eeeee","rrr","ssss","aaaaa"};
int cnt = sizeof(myArray) / sizeof(myArray[0]);
printf("%d\n", sizeof(myArray));
printf("%d\n", sizeof(myArray[0]));
printArray1(myArray,cnt);
sortArray1(myArray,cnt);
printArray1(myArray, cnt);
return 1;
}
//第二种
int main2()
{
char buf[30] = {0};
char myArray[10][30] = { "wwwwwww", "eeeee", "rrr", "ssss", "aaaaa" };
return 1;
}
//第三种
char** getmem3(int num)
{
int i = 0;
char **p = NULL;
p = (char**)malloc(sizeof(char*)*num);
if (p == NULL)
return NULL;
for (i=0; i < num; i++)
{
p[i] = (char*)malloc(sizeof(char*)* 100);
sprintf(p[i], "%d%d%d", i + 1, i + 1, i + 1);
}
return p;
}
int main3()
{
char **p = NULL;
int i = 0;
p = getmem3(5);
for (i = 0; i < 5; i++)
{
printf("%s ",p[i]);
}
printf("\n");
//释放
for(i = 0; i < 5; i++ )
{
if (p[i])
{
free(p[i]);
p[i] = NULL;
}
}
if (p)
{
free(p);
}
return 1;
}