gpt4 book ai didi

c++ - 在另一个 vector 中搜索一个 vector

转载 作者:行者123 更新时间:2023-11-30 02:26:35 27 4
gpt4 key购买 nike

我正在尝试查看 vector v1 是否在 vector v2 内。

例如,如果 v1= (b, a) 且 v2 = (g, e, f, a, b)。我需要检查 v2 中的 b 和 a present。

以下代码仅在顺序相同时对我有帮助。

std::search(v2.begin(), v2.end(), v1.begin(), v1.end());

即,如果 v2 = (g, e, f, b, a)

目前我正在通过以下方式实现

for (std::vector<std::string>::iterator it = v1.begin(); it != v1.end(); ++it)
{
if (std::find(v2.begin(), v2.end(), *it) != v2.end())
std::cout << "found\n";
else
std::cout << "not found\n";
}

有没有办法使用上面的 std::search 来实现?

最佳答案

你可以使用 std::set_intersection :

#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
int main()
{
std::vector<char> v1{'a','b','e','f','g'};
std::vector<char> v2{'a','b'};
std::sort(v1.begin(), v1.end());
std::sort(v2.begin(), v2.end());

std::vector<char> v_intersection;

std::set_intersection(v1.begin(), v1.end(),
v2.begin(), v2.end(),
std::back_inserter(v_intersection));
for(int n : v_intersection)
std::cout << n << ' ';
}

See the reference

请注意,在使用 std::set_intersection 之前,需要使用相同的排序函数对两个 vector 进行排序因为它依赖于使用 operator< 比较元素

另外你可以使用 std::includes

#include <iostream>
#include <algorithm>
#include <cctype>
#include <vector>

int main()
{
std::vector<char> v1 {'a', 'b', 'c', 'f', 'h', 'x'};
std::vector<char> v2 {'a', 'b', 'c'};
std::vector<char> v3 {'a', 'c'};
std::vector<char> v4 {'g'};
std::vector<char> v5 {'a', 'c', 'g'};

for (auto i : v1) std::cout << i << ' ';
std::cout << "\nincludes:\n" << std::boolalpha;

for (auto i : v2) std::cout << i << ' ';
std::cout << ": " << std::includes(v1.begin(), v1.end(), v2.begin(), v2.end()) << '\n';
for (auto i : v3) std::cout << i << ' ';
std::cout << ": " << std::includes(v1.begin(), v1.end(), v3.begin(), v3.end()) << '\n';
for (auto i : v4) std::cout << i << ' ';
std::cout << ": " << std::includes(v1.begin(), v1.end(), v4.begin(), v4.end()) << '\n';
for (auto i : v5) std::cout << i << ' ';
std::cout << ": " << std::includes(v1.begin(), v1.end(), v5.begin(), v5.end()) << '\n';

auto cmp_nocase = [](char a, char b) {
return std::tolower(a) < std::tolower(b);
};

std::vector<char> v6 {'A', 'B', 'C'};
for (auto i : v6) std::cout << i << ' ';
std::cout << ": (case-insensitive) "
<< std::includes(v1.begin(), v1.end(), v6.begin(), v6.end(), cmp_nocase)
<< '\n';
}

输出:

a b c f h x
includes:
a b c : true
a c : true
g : false
a c g : false
A B C : (case-insensitive) true

Here is the reference page(上面的例子直接来自引用)

根据您的尝试,任何一个都可以完成这项工作。

关于c++ - 在另一个 vector 中搜索一个 vector ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42560182/

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