字符串C++中的分隔符字符
问题描述:
这是要求:读取一个字符串并循环它,每当遇到一个新字时,将它插入到std :: list中。如果。字符在左侧有一个空格,制表符,换行符或数字,在右侧有一个数字,则它被视为一个小数点,因此是一个单词的一部分。否则它会被视为句号和字词分隔符。字符串C++中的分隔符字符
这是我从模板程序运行结果:
foo.bar -> 2 words (foo, bar)
f5.5f -> 1 word
.4.5.6.5 -> 1 word
d.4.5f -> 3 words (d, 4, 5f)
.5.6..6.... -> 2 words (.5.6, 6)
看来我在第一时间处理串c非常复杂++。我真的坚持执行代码。任何人都可以提示我一个提示吗?由于
我只是做了一些思想从无到有
bool isDecimal(std::string &word) {
bool ok = false;
for (unsigned int i = 0; i < word.size(); i++) {
if (word[i] == '.') {
if ((std::isdigit(word[(int)i - 1]) ||
std::isspace(word[(int)i -1]) ||
(int)(i - 1) == (int)(word.size() - 1)) && std::isdigit(word[i + 1]))
ok = true;
else {
ok = false;
break;
}
}
}
return ok;
}
void checkDecimal(std::string &word) {
if (!isDecimal(word)) {
std::string temp = word;
word.clear();
for (unsigned int i = 0; i < temp.size(); i++) {
if (temp[i] != '.')
word += temp[i];
else {
if (std::isalpha(temp[i + 1]) || std::isdigit(temp[i + 1]))
word += ' ';
}
}
}
trimLeft(word);
}
答
实现我想你可能会从错误的方向接近的问题。如果您将条件颠倒,似乎更容易。给你一些伪代码骨架中的指针:
bool isSeparator(const std::string& string, size_t position)
{
// Determine whether the character at <position> in <string> is a word separator
}
void tokenizeString(const std::string& string, std::list& wordList)
{
// for every character in string
// if(isSeparator(character) || end of string)
// list.push_back(substring from last separator to this one)
}
请告诉我们你到目前为止。 – NPE 2012-04-28 17:24:35
您的示例似乎并不符合要求,除了第1行和第3行 – smocking 2012-04-28 17:28:38
这就是模板程序的预期输出。 – Harry 2012-04-28 17:31:23