#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.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论