题目描述
先输入你要输入的字符串的个数。然后换行输入该组字符串。每个字符串以回车结束,每个字符串少于一百个字符。 如果在输入过程中输入的一个字符串为“stop”,也结束输入。 然后将这输入的该组字符串按每个字符串的长度,由小到大排序,按排序结果输出字符串。
输入描述:
字符串的个数,以及该组字符串。每个字符串以‘\n’结束。如果输入字符串为“stop”,也结束输入.
输出描述:
可能有多组测试数据,对于每组数据, 将输入的所有字符串按长度由小到大排序输出(如果有“stop”,不输出“stop”)。 根据输入的字符串个数来动态分配存储空间(采用new()函数)。每个字符串会少于100个字符。 测试数据有多组,注意使用while()循环输入。
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
bool cmp(string a,string b)
{
return a.size()<b.size();
}
int main()
{
int n;
string s;
vector<string>v;
while(cin>>n)
{
getline(cin,s);//特别重要,把换行符吃掉,否则后面全部不对
for(int i=0;i<n;i++)
{
getline(cin,s);
if(s=="stop")
{
break;
}
else{
v.push_back(s);
}
}
sort(v.begin(),v.end(),cmp);
for(int i=0;i<v.size();i++)
{
cout<<v[i]<<endl;
}
v.clear();
}
return 0;
}