我如何在我的句子中找到'w'字符的第一个单词。这个单词可以出现在我的单词的任何地方。例子的句子“Hi xyzwy ! 你在这里做什么?”所以结果应该是“xyzwy”。如何找到句子中有'w'的第一个单词
2
A
回答
3
从第一个字符开始,直到最后一个字符为止。检查你是否遇到'w'。如果是的话,直到你敲击字词分隔符(例如空格)或者到达字符串的开头,然后打印所有字符,直到遇到另一个字词分隔符(或字符串末尾)。
string Str;
getline(cin, Str);
for (int i = 0; i < Str.length(); ++i)
if (Str[i] == 'w')
{
// backtrack and print
break;
}
或者使用String类的find method做搜索你,那么你只需要确定这个词。
1
boost::optional<std::string>
find_word_with(std::string const& haystack, std::string const& needle) {
std::istringstream ss (haystack);
for (std::string word; ss >> word;) {
if (word.find(needle) != word.npos) {
return boost::optional<std::string>(word);
}
}
return boost::optional<std::string>();
}
std::string const whitespace = " \t\r\n\v\f";
boost::optional<std::string>
find_word_with2(std::string const& haystack, std::string const& needle) {
typedef std::string::size_type Pos;
Pos found = haystack.find(needle);
if (found == haystack.npos) {
return boost::optional<std::string>();
}
Pos start = haystack.find_last_of(whitespace, found);
if (start == haystack.npos) start = 0;
else ++start;
Pos end = haystack.find_first_of(whitespace, found+1);
if (end == haystack.npos) end = haystack.length();
return boost::optional<std::string>(haystack.substr(start, end - start));
}
双方对这些空白只单独的单词(我错过了你想要的“xyzwy”,而不是“xyzwy!”在第一),但你可以修改它们忽略标点符号。第一个不太适合,但第二个可以很容易地修改为使用find_first/last_ 而不是 _of与等效的正则表达式\w
(“ABC..abc..012 .._”),而不是检查空白。
请注意,第二个使用硬编码的空白变量,由于流解决方案(它使用最后设置的全局语言环境)而不是区域意识,但它可能正是您想要的。
int main() {
{
boost::optional<std::string> r =
find_word_with("Hi xyzwy! what are you doing here?", "w");
if (!r) std::cout << "not found\n";
else std::cout << "found: " << *r << '\n';
}
{
boost::optional<std::string> r =
find_word_with2("Hi xyzwy! what are you doing here?", "w");
if (!r) std::cout << "not found\n";
else std::cout << "found: " << *r << '\n';
}
return 0;
}
1
如果你真的需要正则表达式,你可以使用
\w*w\w*
例如:
#include <boost/regex.hpp>
#include <string>
#include <iostream>
using namespace boost;
using namespace std;
int main() {
string s;
getline(cin, s);
match_results<string::const_iterator> m;
if (regex_search(s, m, regex("\\w*w\\w*"))) {
cout << "Found: " << string(m[0].first, m[0].second) << "\n";
} else {
cout << "Not found\n";
}
return 0;
}
相关问题
- 1. 找到两个句子之间匹配的第一个单词
- 2. 如何找到一个句子的第一个单词只有三个不同的选项
- 3. 在Java中看到的句子的第一个单词
- 4. 从句子中删除除第一个单词以外的所有单词
- 5. 有没有办法找到Python中句子中第二长的单词?
- 6. 如何找到一列中的单词/单词出现在另一列中构成一个句子
- 7. 如何使用Regex找到所有单词的句子?
- 8. 打印每个单词的第一个字母一个句子
- 9. 获取句子中每个单词的第一个字母?
- 10. 提取句子中每个单词的第一个字母
- 11. 如何找到每个单词的第一个字母?
- 12. 第一个重复的单词在句子中
- 13. JavaScript正在使用句子中的第一个单词
- 14. Solr lucene仅搜索句子中的第一个单词 - need query
- 15. 计算句子第一个单词中的字母数
- 16. 的Javascript:想找到句子中的所有单词,@
- 17. 如何找到一个单词之前没有另一个特定的单词?
- 18. 找到句子中所有单词的排列组合
- 19. 如何在vim中找到一个单词的第一个大写字母? e。
- 20. 递归查找一个句子中最长的单词
- 21. 如何添加(追加)一个单词到同一个句子,每个单词使用一个按钮(单击)
- 22. 如何迭代C++中的一个句子的单词?
- 23. 如何进入TextView |中第二个找到的单词ANDROID
- 24. 如何在WPF RichTextBox中找到第N个单词的TextRange?
- 25. 使用CSS设置句子的第一个单词
- 26. 为什么ZeroClipboard只复制句子的第一个单词?
- 27. 如何匹配句子中的最后一个单词?
- 28. 如何计算句子中的单词?
- 29. 如何选择一个句子的前10个单词?
- 30. preg_replace在句子中的“单词”和“单词”。在句子结尾
'提振:: regex'? – AraK 2010-03-14 08:44:48
需要功课标签吗? – 2010-03-14 08:48:02