问题是我想比较一个字符串中的字符,对于每个字符,它是否属于字母表;是小写还是大写。我怎么能这样做?将一个字符与C++中的各种字符类进行比较
这是很好,如果我想比较它像(+ - * ^)像没有标准功能。 PLZ帮我出
问题是我想比较一个字符串中的字符,对于每个字符,它是否属于字母表;是小写还是大写。我怎么能这样做?将一个字符与C++中的各种字符类进行比较
这是很好,如果我想比较它像(+ - * ^)像没有标准功能。 PLZ帮我出
#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);
您可以轻松地使用std::find
算法:
const std::string alphabet = "abcdefghijklmnopqrstuvwxyz";
bool is_in_alphabet
= std::find(alphabet.begin(), alphabet.end(), 'c') != alphabet.end();
或者,如果字母字符是排序的,则可以使用std::binary_search
,但除非字母表中的字符数很多(即大于26),否则线性搜索可能会快得多。字符很小,而且很快比较。
感谢托尼ü太伟大和计算器太 – maverick 2011-02-04 06:22:21
PLZ看看我编辑的问题 – maverick 2011-02-04 06:36:45