函数接口定义:
int input(char ar2[][21]); 其中函数的返回值等于输入的有效单词的数目。 void paixu(char ar2[][21], int n); 其中函数完成对ar2数组中的n个字符串进行排序。 void printArr(char ar2[][21], int n); 其中函数完成对ar2数组中的n个字符串进行输出。
输入样例:
China Britain America Japan Egypt *END*
输出样例:
After sorted:
America Britain China Egypt Japan
输入样例:
*END*
输出样例:
NO WORD
输入样例:
a1 b2 c3 d4 e5 a6 b7 c8 d9 e10 a11 b12 c13
输出样例:
After sorted:
a1 a6 b2 b7 c3 c8 d4 d9 e10 e5
int input(char ar2[][21])
{
int i=0;
for(i=0;i<10;i++)//此处控制了输入最多次数,也可以使用while循环
{
scanf("%s",ar2[i]);
if(strcmp(ar2[i],"*END*")==0)//简单的判断,如果输入了*END*就结束循环即输入
{
break;
}
}
return i;
}
//简单的冒泡排序给二维字符数组排序
void paixu(char ar2[][21], int n)
{
for(int i=0;i<n;i++)
{
for(int j=0;j<n-i-1;j++)
{
if(strcmp(ar2[j],ar2[j+1])>0)
{
char temp[21]={0};
strcpy(temp,ar2[j]);
strcpy(ar2[j],ar2[j+1]);
strcpy(ar2[j+1],temp);
}
}
}
}
//输出函数,输出时注意格式否则会报错
void printArr(char ar2[][21], int n)
{
if(n==0)
{
printf("NO WORD");
}
else
{
printf("After sorted:\n");
for(int i=0;i<n-1;i++)
{
printf("%s ",ar2[i]);
}
printf("%s",ar2[n-1]);
}
}