H2330819064


私信TA

用户名:dotcpp0701282

访问量:398

签 名:

找luogu玩去了,告辞

等  级
排  名 297
经  验 5604
参赛次数 0
文章发表 2
年  龄 0
在职情况 学生
学  校 贺州学院
专  业

  自我简介:

TA的其他文章

#include<stdio.h>
#include<math.h>
#include<string.h>
void swapstr(char*,char*);
void swapstr(char* a,char* b)
{
	char c[10000];
	strcpy(c,a);
	strcpy(a,b);
	strcpy(b,c);
}
int main()
{
	int n;
	while(~scanf("%d",&n))
	{
		char a[1000][10000]={0};
		int nn=n;
		while(n>0) 
		{
			n--;
			scanf("%s",a[n]);
		}
		int sum;
		for(int b=1;b<nn;b++){//从小到大 先排长度 
			sum=0; 
			while(strlen(a[b-sum])<strlen(a[b-1-sum]))
			{
				swapstr(a[b-sum],a[b-1-sum]);
				sum++;
				if(b-1-sum<0)
				{
					break;
				}
			}
		}
		for(int b=1;b<nn;b++){
			sum=0;
			while(b-1-sum>=0) 
			{
				if(strlen(a[b-sum])==strlen(a[b-1-sum]))
				{
					if(strcmp(a[b-sum],a[b-1-sum])<0)
					{
						swapstr(a[b-sum],a[b-1-sum]);
					}	
				}
				sum++;
			}
		}
		for(int b=0;b<nn;b++){
			printf("%s\n",a[b]);
		}
	}
	return 0;
}

解题思路:

注意事项:

参考代码:

 

0.0分

2 人评分

  评论区

  • «
  • »