uva-400-Unix ls

这道题目的大体意思是:

给你一些单词,先按字典序排列,然后再把排过序的单词按列输出。

答题思路:

用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;
}

你可能感兴趣的:(ini)