英文单词排序(PTA-武理-C实验)

本题要求编写程序,输入若干英文单词,对这些单词按长度从小到大排序后输出。如果长度相同,按照输入的顺序不变。
输入格式:
输入为若干英文单词,每行一个,以#作为输入结束标志。其中英文单词总数不超过20个,英文单词为长度小于10的仅由小写英文字母组成的字符串。
输出格式:
输出为排序后的结果,每个单词后面都额外输出一个空格。
输入样例:
blue
red
yellow
green
purple

输出样例:
red blue green yellow purple

#include<stdio.h>
#include<string.h>
int main()
{
    int n,i,j;
 char a[20][10];char t[10];
 while (1) {
  scanf("%s", a[i]);
  if (a[i][0] == '#')
   break;
  i++;n=i;
 }
    a[i] = '\0';
 for (i = 0; i < n; i++)
    { for (j = 1; j < n - i; j++)
   if (strlen(a[j - 1]) > strlen(a[j]))
   {strcpy(t, a[j - 1]);strcpy(a[j - 1], a[j]);strcpy(a[j],t);}
    }
     for (i = 0; i <n; i++)
  printf("%s ", a[i]);
 return 0;
}

版权声明:本文为fqs1594916898原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。