在c++中使用向量设置联合算法
Set union algorithm using vector in C++
在这个问题中我只使用std::vector
,并且我可以保证每个向量中没有重复(但是每个向量中没有任何顺序)。如何对这些向量进行并集?
的例子:
如果我有以下向量…
1
1
3 2
5
5 4
2
4
4 2
并集之后应该只剩下两个向量:
1
2 3 4 5
我只使用向量,不允许使用std::set
可以使用std::set_union算法
int first[] = {5,10,15,20,25};
int second[] = {50,40,30,20,10};
std::vector<int> v(10); // 0 0 0 0 0 0 0 0 0 0
std::vector<int>::iterator it;
std::sort (first,first+5); // 5 10 15 20 25
std::sort (second,second+5); // 10 20 30 40 50
it=std::set_union (first, first+5, second, second+5, v.begin());
// 5 10 15 20 25 30 40 50 0 0
v.resize(it-v.begin()); // 5 10 15 20 25 30 40 50
参考:http://www.cplusplus.com/reference/algorithm/set_union/
对向量进行排序,然后像合并排序一样合并它们,但不要插入重复项。
vector<int> a, b, c;
sort( a.begin(), a.end());
sort( b.begin(), b.end());
int i = 0, j = 0;
while( i < a.size() && j < b.size())
if( a[ i ] == b[ j ] )
{
c.push_back( a[ i ] );
++i, ++j;
}
else if( a[ i ] < b[ j ] )
c.push_back( a[ i++ ] );
else
c.push_back( b[ j++ ] );
while( i < a.size()) c.push_back( a[ i++ ] );
while( j < b.size()) c.push_back( b[ j++ ] );
下面是我的代码:
template<class T> bool vectorExist (vector<T> c, T item)
{
return (std::find(c.begin(), c.end(), item) != c.end());
}
template<class T> vector<T> vectorUnion (vector<T> a, vector<T> b)
{
vector<T> c;
std::sort(a.begin(), a.end());
std::sort(b.begin(), b.end());
auto i = a.begin();
auto j = b.begin();
while (i != a.end() || j != b.end())
{
if (j == b.end() || *i < *j)
{
if(!exist(c,*i)) c.insert(*i);
i++;
}
else
{
if(!exist(c,*j)) c.insert(*j)
j++;
}
}
return c;
}
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 在C++/Linux中设置单调时钟的一些技巧
- 如何在选项卡视图Qt中设置一个新项目,并保存以前的项目
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 嵌套在类中时无法设置成员数据
- 需要帮助设置在C++中使用的Potrace
- 基于ELO的团队匹配算法
- 如何在自删除后将对象设置为nullptr
- C++选择排序算法中的逻辑错误
- 有没有办法将谓词中的元素偏移量传递给 std 算法?
- 将指针设置为"nullptr"并不能防止双重删除?
- C++A*算法并不总是在路径中具有目标节点
- 排序算法c++
- 如何在Ubuntu中使用cmake设置qt4
- ld:bind_at_load和-bitcode_bundle(Xcode设置ENABLE_bitcode=YES)不能
- 如何优化标准::设置交集算法(C++)
- 这种计算 32 位整数中设置位数的算法如何工作
- 使用C++设置合并算法
- 设置以哈希算法为边界
- 在c++中使用向量设置联合算法