酱酱


私信TA

用户名:H2130823055

访问量:6955

签 名:

我が名はめぐみん、爆裂魔法を操りし者

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

  自我简介:

TA的其他文章

这个题目的难点在于剔除含有相同数字和个数的字符,本蒟蒻第一时间想到的是将每个数字改成字符串然后将每个字符串都排序一遍,这样就变成了相同的数。

ac代码:

#include<bits/stdc++.h>
using namespace std;
map<string,int>ma;
set<string>se;
struct str//保存当前字符串和该字符串排序后的字符串
{
	string s;
	string ss;
}str[10005];
bool cmp(char a,char b)
{
	return a<b;
}
int main()
{
	int n;
	while((scanf("%d",&n))&&n!=0)
	{
		for(int i=0;i<n;i++)
		{
			string s;
			cin>>s;
			str[i].s=s;
			int l=s.length();
			sort(s.begin(),s.end(),cmp);//从小到大排序
			str[i].ss=s;
			ma[s]++;//对每个排序后的字符串数量保存下来
		}
		for(int i=0;i<n;i++)
		{
			if(ma[str[i].ss]==1)//如果该字符串只出现一次,就装如set
			{
				se.insert(str[i].s);
			}
		}
		if(se.empty())//如果set为空就输出None
		{
			printf("None\n");
			continue;
		}
		set<string>::iterator it;
		for(it=se.begin();it!=se.end();it++)//输出
		{
			cout<<*it<<' ';
		}
		cout<<endl;
		ma.clear();//清空map
		se.clear();//清空set
	}
	return 0;
}


 

0.0分

3 人评分

  评论区

  • «
  • »