UVa10815 - Andy's First Dictionary

题目地址:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&category=20&problem=1756&mosmsg=Submission+received+with+ID+12174014

C++代码:

 

#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
#include <cctype>
using namespace std;
int main()
{
	string s;
	vector<string> svec;
	while(getline(cin,s))
	{
		int i;
		for(i=0;i<(int)s.size();++i)
		{
			if(isupper(s[i]))
				s[i]=s[i]-'A'+'a';
		}
		string::iterator begin=s.begin();
		for(;begin!=s.end()&&!isalpha(*begin);++begin);
		string::iterator end;
		if(begin==s.end())
			end=begin;
		else
			end=begin+1;
		while(true)
		{
			if(begin==s.end())
				break;
			for(;end!=s.end()&&isalpha(*end);++end);
			string str(begin,end);
			vector<string>::iterator iter=find(svec.begin(),svec.end(),str);
			if(iter==svec.end())
				svec.push_back(str);
			for(;end!=s.end()&&!isalpha(*end);++end);
			begin=end;
			if(end!=s.end())
				++end;
		}
	}
	sort(svec.begin(),svec.end());
	vector<string>::iterator iter=svec.begin();
	while(iter!=svec.end())
		cout<<*iter++<<endl;
	return 0;
}


 

 

posted @   jlins  阅读(511)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
点击右上角即可分享
微信分享提示