随笔 - 66  文章 - 0  评论 - 0  阅读 - 22203

1926: 2018蓝桥杯培训-STL应用专题-day 2 vector作业题1

描述

题目描述:

字符串有些是对称的,有些不是对称的,请将那些对称的字符串安从小到大的顺序输出,字符串先以长度论大小,如果长度相等,再以ASCII码值为排序标准;

输入:

输入一个n,表示接下来有n组字符串,串长<=256; n<=1000;

输出:

根据每个字符串,输出对称的那些串,并且要求按从小到大的顺序输出;

样例输入

7
123321
123454321
123
321
sdfsdfd
\\dd\\
121212

样例输出

123321
\\dd\\
123454321
#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
using namespace std;
vector<string> s;

bool cmp(string &s1, string &s2)
{
	if(s1.size() == s2.size())
	{
		return s1 < s2;
	}
	else
	{
		return s1.size() < s2.size();
	}
}

int main(int argc, char** argv) 
{
	int n = 0;
	int j = 0;					
	string str;
	cin >> n;
	for(int i = 0; i < n; i++)
	{
		cin >> str;
		s.push_back(str);
		reverse(s[j].begin(), s[j].end());
		if(str == s[j])
		{
			j++;
		}
		else
		{
			s.pop_back();
		}
	}
    sort(s.begin(), s.end(), cmp);
    for(int i = 0; i < j; i++)
    {
    	cout << s[i] << endl;
	}
	
	return 0;
}

 

posted on   Daniel_lmz  阅读(23)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示