2011-02-04 25 views

回答

5
#include <cctype> 
#include <string> 

... 

for (std::string::const_iterator i = s.begin(); i != s.end(); ++i) 
    if (std::isalpha(*i)) 
     handle_alphabetic_character(*i); 
    else 
     handle_non_alphabetic_character(*i); 

编辑新的要求:

要查找任意字符集,你可以使用任何STR :: find()方法在他的回答詹姆斯MeNellis文件,或者干脆...

#include <cstring> 

for (std::string::const_iterator i = s.begin(); i != s.end(); ++i) 
    if (std::strchr("*+{\\&", *i)) 
     handle_matching_character(*i); 
    else 
     handle_non_matching_character(*i); 
+0

感谢托尼ü太伟大和计算器太 – maverick 2011-02-04 06:22:21

+0

PLZ看看我编辑的问题 – maverick 2011-02-04 06:36:45

2

您可以轻松地使用std::find算法:

const std::string alphabet = "abcdefghijklmnopqrstuvwxyz"; 

bool is_in_alphabet 
      = std::find(alphabet.begin(), alphabet.end(), 'c') != alphabet.end(); 

或者,如果字母字符是排序的,则可以使用std::binary_search,但除非字母表中的字符数很多(即大于26),否则线性搜索可能会快得多。字符很小,而且很快比较。

相关问题