English 中文(简体)
在矢量 c++ 中获取字符串数
原标题:Getting count of strings in vector c++

我有这个矢量

vector <string> data

data = ["this is", "data that", "is in", "this is", "vector", "vector", "vector"]

我如何获得一个矢量( 或 2D 数组) 来移除重复内容, 取而代之的是每个 Ith 项的计数?

或(或)

 results = [("this is", 2), ("data that", 1), ("is in", 1), ("vector", 3)]
最佳回答

直截了当的解决办法是将独特价值及其计算汇集到一张地图中:

std::map<std::string, std::size_t> results;
std::for_each(begin(data), end(data), [&](std::string const& s)
{
    ++results[s];
});

这具有线性对数( n lg n) 时间复杂性, 虽然因为它必须复制每个不同的字符串值, 费用可能相当昂贵 。 您也可以在位置上排序列表, 然后计算每个值的数量, 如果您对 < code>std:: string 进行移动认知执行, 效果会更好 。

问题回答

暂无回答




相关问题
Simple JAVA: Password Verifier problem

I have a simple problem that says: A password for xyz corporation is supposed to be 6 characters long and made up of a combination of letters and digits. Write a program fragment to read in a string ...

Case insensitive comparison of strings in shell script

The == operator is used to compare two strings in shell script. However, I want to compare two strings ignoring case, how can it be done? Is there any standard command for this?

Trying to split by two delimiters and it doesn t work - C

I wrote below code to readin line by line from stdin ex. city=Boston;city=New York;city=Chicago and then split each line by ; delimiter and print each record. Then in yet another loop I try to ...

String initialization with pair of iterators

I m trying to initialize string with iterators and something like this works: ifstream fin("tmp.txt"); istream_iterator<char> in_i(fin), eos; //here eos is 1 over the end string s(in_i, ...

break a string in parts

I have a string "pc1|pc2|pc3|" I want to get each word on different line like: pc1 pc2 pc3 I need to do this in C#... any suggestions??

Quick padding of a string in Delphi

I was trying to speed up a certain routine in an application, and my profiler, AQTime, identified one method in particular as a bottleneck. The method has been with us for years, and is part of a "...

热门标签