#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int cmp(const void *a,const void *b)
{
return strcmp((char *)a,(char *)b);
}
int main()
{
int i,j,k,max_len,n;
int h_num,l_num,num_len;
char str[110][100];
while(scanf("%d",&n)!=EOF)
{
max_len=0;
for(i=0;i<n;i++)
{
scanf("%s",str[i]);
if(strlen(str[i])>max_len)
max_len=strlen(str[i]);
}
qsort(str,n,100*sizeof(char),cmp);
printf("------------------------------------------------------------\n");
h_num=62/(max_len+2);
l_num=(n-1)/h_num+1; //非常好的方法~
for(i=0;i<l_num;i++)
{
for(j=0;j<h_num;j++)
{
if(j*l_num+i>=n)
break;
printf("%s",str[j*l_num+i]); //当已经知道有几行时,如何正确横着输出已经排好序的字符串~good!
num_len=max_len-strlen(str[j*l_num+i]);
for(k=0;k<num_len;k++)
{
printf(" "); //如果你真的非要这么控制格式的话,我也没办法。。
}
if(j!=h_num-1)
printf(" ");
}
printf("\n");
}
}
return 0;
}
UVA 400 unix is
最新推荐文章于 2019-08-22 16:01:19 发布