这道题目的大体意思是:
给你一些单词,先按字典序排列,然后再把排过序的单词按列输出。
答题思路:
用qsort排序,我发现最近经常用qsort,很好用的。然后算出来一共有几行,有几列。然后输出对应的字符串。
我在写程序的时候,错误的在for循环后面加了一个";"然后检查的时候也没检查出来,让后就悲剧的在这上面检查了好久好久~~
#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]);
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;
}