gpt4 book ai didi

C++ 计算功能词出现次数

转载 作者:塔克拉玛干 更新时间:2023-11-03 07:45:57 24 4
gpt4 key购买 nike

我正在尝试计算文本文件中特定单词的出现次数,问题是当我的代码读取文件时 - 它正在使用空白分隔符读取它,但我想要计算的一些单词是“2个单词”例如“out from”

除此之外还有第二个问题,那就是像“不是”和“不要”这样的词——我的代码似乎忽略了这些词,即使我在 map 中用反斜杠放置它们——我的猜测是由于某种原因,它在从文件中读取它的过程中被忽略了

我正在寻找的最终结果是我正在搜索的词的频率。

std::list<std::string> Fwords = {
"a","abroad","as far as","ahead of"};

// Begin reading from file:
std::ifstream fileStream(fileName);

// Check if we've opened the file (as we should have).
if (fileStream.is_open())
while (fileStream.good())
{
// Store the next word in the file in a local variable.
std::string word;
fileStream >> word;
std::cout << "This is the word: " << word << endl;

if (std::find(std::begin(Fwords), std::end(Fwords), word) != std::end(Fwords))
wordsCount[word]++;
}

输入:

 "ahead of me as far as abroad me"

这将是预期的输出:

abroad:1
ahead of:1
as far as:1

最佳答案

这种方法行不通。您的问题是您一次从文件 中读取一个单词。再多的反斜杠或操纵单词列表/映射也无法解决这个问题。

但是你怎么知道要读多少字呢?你不需要——它必须反复试验。

考虑到您的编程水平,一种“暴力破解”的方法是将 else 添加到

if (std::find(std::begin(Fwords), std::end(Fwords), word) != std::end(Fwords))
{
// ...
}

您在其中检查 map 中以文件中的单词开头的单词,例如“as”,但带有空格,因此搜索是作为。如果找到一个或多个匹配项,就该从文件中读取另一个词了,例如“as far”。这应该放在循环中(或在循环中调用的函数),以便自动搜索 as far 并读取另一个单词“as”。成功找到 as far as 后,您就完成了。如果找不到 as as far as far as,您也完成了, 如果您如果你的 map 中没有这些,在这种情况下,你想对每个单词运行一个 for 循环来检查它们是否是单独的单词,如果是则增加它们的计数。在此过程中,您将意识到您需要与原始代码相同的代码;所以将它也分解为一个函数是明智的。

关于C++ 计算功能词出现次数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38465246/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com