瞌睡小源


私信TA

用户名:H2130823055

访问量:4773

签 名:

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

等  级
排  名 45
经  验 11489
参赛次数 5
文章发表 76
年  龄 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 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区