단어 수

1714 단어
제목:
작은 문장은 모두 소문자와 빈칸으로 구성되어 문장부호가 없어 한 문장의 서로 다른 단어의 총수를 통계한다.
STL 학습, set 및 string 응용 프로그램을 배웠습니다.
구체적인 보기 코드:
#include <iostream>  
#include <set>  
#include <string>  
#include <sstream>//       

using namespace std;  

int main() {  
	string art;  
	while(getline(cin,art) && art != "#"){  
		istringstream stream(art);  
		string word;  
		set<string> map;  
		while(stream >>word){  
			map.insert(word);  
		}  
		cout <<map.size() <<endl;  
	}  
	return 0;  
}
#define CY 1000000
char str[CY];

set<string> st;
int main(void) {
	while (gets(str) && str[0] != '#') {
		st.clear();
		int len = (int)strlen(str), sum = 0;
		bool flag = false;
		string S = "";
		for (int i = 0; i <= len; ++i) {
			if (str[i] >= 'a' && str[i] <= 'z') {
				S += str[i];
				flag = true;
			} else if (flag) {
				if (!st.count(S)) st.insert(S);
				flag = false;
				S.clear();
			}
		}
		printf("%d
", st.size()); } return 0; }
string s;
map<string, int> maps;

int main() {
	while(getline(cin, s)) {
		if(s == "#") break;
		LL len = s.length(), ans = 0;
		maps.clear();
		for(LL i = 0; i < len; ++i) {
			if(s[i] == ' ') {
				continue;
			}
			string t = "";
			for(; i < len; ++i) {
				if(s[i] != ' '){
					t += s[i];
				}else {
					break;
				}
			}
		//	cout<< t << ans << endl; 
			if(maps[t] == 0) {
				maps[t] = 1;
				ans++; 
			} 
		}
		cout<< ans<< endl;
	}
	return 0;
} 

좋은 웹페이지 즐겨찾기