7-1 英文单词排序 (25 分)

本题要求编写程序,输入若干英文单词,对这些单词按长度从小到大排序后输出。如果长度相同,按照输入的顺序不变。

输入格式:

输入为若干英文单词,每行一个,以#作为输入结束标志。其中英文单词总数不超过20个,英文单词为长度小于10的仅由小写英文字母组成的字符串。

输出格式:

输出为排序后的结果,每个单词后面都额外输出一个空格。

输入样例:

blue
red
yellow
green
purple
#

输出样例:

red blue green yellow purple 

c和c++都可以。这里c采用冒泡排序的方法,c++用sort就行。

c语言版:

# include<stdio.h>
# include<string.h>
int main()
{
	char s[100][10];
	int a[100]={0};
	char t[10];
	int i=0,j,z;
	while(1)
	{
		scanf("%s",s[i]);
		if(s[i][0]=='#')
			break;
		i++;
	}
	for(j=0;j<i-1;j++)
		for(z=0;z<i-j-1;z++)
			if(strlen(s[z])>strlen(s[z+1]))
			{
				strcpy(t,s[z]);
				strcpy(s[z],s[z+1]);
				strcpy(s[z+1],t);		
			}
	for(j=0;j<i;j++)
		printf("%s ",s[j]);
}

c++版:

#include<bits/stdc++.h>
using namespace std;
bool cmp(string a,string b)
{
	return a.size()<b.size();
}
int main()
{
	int j;
	string s[20];
	int i=0;
	while(1)
	{
		cin>>s[i];
		if(s[i]=="#")
			break;
		i++;
	}
	sort(s,s+i,cmp);
	for(j=0;j<i;j++)
		cout<<s[j]<<" ";
} 

 


版权声明:本文为qq_40986486原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/qq_40986486/article/details/85224209