#include <stdio.h>
#include <string.h>
int main(void)
{
char str[3][20],*p[3],temp[20];
int i,j;
for(i=0;i<3;i++)
{
p[i]=str[i];// p[I]为指针变量.p[I]指向行地址。
gets(p[i]);
}
for(i=0;i<3-1;i++)选择排序。
for(j=i+1;j<3;j++)
{
if( strcmp(p[i],p[j])>0)
{
strcpy(temp,p[i]);
strcpy(p[i],p[j]);
strcpy(p[j],temp);
}
}
printf("排序后的字符串为:\n");
for(i=0;i<3;i++)
puts(p[i]);
#include <string.h>
int main(void)
{
char str[3][20],*p[3],temp[20];
int i,j;
for(i=0;i<3;i++)
{
p[i]=str[i];// p[I]为指针变量.p[I]指向行地址。
gets(p[i]);
}
for(i=0;i<3-1;i++)选择排序。
for(j=i+1;j<3;j++)
{
if( strcmp(p[i],p[j])>0)
{
strcpy(temp,p[i]);
strcpy(p[i],p[j]);
strcpy(p[j],temp);
}
}
printf("排序后的字符串为:\n");
for(i=0;i<3;i++)
puts(p[i]);
return 0;}
//我们了解要存取多个字符串,用二维数组简单。首先要理解指针数组。*p[20]。[ ]比*的优先级高。是指针数组。顾名思义,就是每一个数组元素都是一个指针变量。
排序就是利用选择排序。(不懂排序自己去了解)。这里不做解释