我目前正在尝试编写代码来查找唯一的行以及唯一的单词。我在下面列出了我尝试过的唯一行代码,但是当涉及到唯一行时它没有正确计算。我相信它忽略了输入并且仍在计算包含字母,单词,句子等的行。所以我需要帮助确定要添加的内容,它将计入输入(空白行)作为行并且不计算任何额外的行是相同。我知道这种情况正在发生,因为我已经测试了几条不同的线路。至于独特的单词,我甚至不知道如何开始:/
unsigned long countULines(const string& s)
{
set<string> wl;
string ulines;
for(int ul = 0; ul < s.size(); ul++){
wl.insert(ulines);
}
return wl.size();
}
答案 0 :(得分:0)
这对你有用:
#include <iostream>
#include <sstream>
#include <string>
#include <set>
size_t countUniqueLines(const std::string& s)
{
std::set<std::string> uniqueLines;
std::istringstream is(s);
std::string line;
while (std::getline(is, line)) {
if (!line.empty() && line[line.size() - 1] == '\r') {
line.erase(line.size() -1);
}
uniqueLines.insert(line);
}
return uniqueLines.size();
}
int main()
{
const std::string myLines = "four\none\n\ntwo\nthree\nthree\n\n";
std::cout << countUniqueLines(myLines) << std::endl;
}