UVa10815

题目地址: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;
}


原文地址:https://www.cnblogs.com/dyllove98/p/3243864.html