我是 C++ 的新手(来自 Python),我试图找出一种比较两个不同大小的向量的好方法,每个向量都包含字符串向量,以找到它们之间的匹配向量。我试过 == 但这显然只是比较迭代器而不是它们的内容。
问问题
2049 次
3 回答
1
找出共同的子向量:
#include <vector>
#include <iostream>
#include <string>
int main()
{
std::vector<std::vector<std::string> > data1; // init here
std::vector<std::vector<std::string> > data2; // init here
std::vector<std::vector<std::string> > results;
// common sub vectors put in result
std::set_union(data1.begin(),data1.end(), data2.begin(), data2.end(),
std::back_inserter(results));
}
但这可能无法回答您的基本问题:
行间阅读:
您正在使用迭代器对两个向量进行迭代:
std::vector<std::vector<std::string> >::const_iterator loop1 = /* Get some part of data1 */;
std::vector<std::vector<std::string> >::const_iterator loop2 = /* Get some part of data2 */;
// loop1/loop2 are iterators in-to your vec/vec/string
// Thus de-referencing them will give you a (const) reference to vec/string
// Thus you should be able to compare them with `==`
if ((*loop1) == (*loop2))
{
std::cout << "They are the same\n";
}
于 2013-01-31T19:14:59.490 回答
1
所以你想比较内部向量?像这样的东西应该可以工作(使用 gcc 4.7):
typedef vector< vector<string> > VectorOfVector;
VectorOfVector v1 = { {"ab", "cd"}, { "ab" } }, v2 = { {"xy"}, {"ab"}};
for(vector<string> & v1item : v1) {
for(vector<string> & v2item : v2) {
if (v1item == v2item) cout << "found match!" << endl;
}
}
于 2013-01-31T19:02:49.480 回答
1
#include <algorithm>
#include <vector>
#include <string>
#include <iostream>
using namespace std;
int main()
{
vector<vector<string>> v1 = { {"abc", "012"}, {"xyz", "9810"}};
vector<vector<string>> v2 = { {"pqr", "456"}, {"abc", "012"}, {"xyz", "9810"}};
vector<pair<size_t, size_t>> matches;
for (auto it1 = v1.cbegin(); it1 != v1.cend(); ++it1)
{
auto it2 = find(v2.cbegin(), v2.cend(), *it1);
if (it2 != v2.cend())
{
matches.push_back(make_pair(it1 - v1.cbegin(), it2 - v2.cbegin()));
}
}
for_each(matches.cbegin(), matches.cend(), [](const pair<size_t, size_t> &p)
{
cout << p.first << "\t" << p.second << endl;
});
}
这会将两个向量中的所有匹配索引值成对打印。您可以使用相应向量的 [ ] 运算符读取匹配向量的内容。
于 2013-01-31T19:05:21.863 回答