最常用方法是使用insert()函数将一个vector的元素插入到另一个vector末尾。示例中vec1.insert(vec1.end(), vec2.begin(), vec2.end())可高效合并两个向量,适用于大多数场景;也可用std::copy配合back_inserter实现,代码清晰但性能略低;范围for循环方式易理解但大量数据时效率较低;C++11及以上支持移动语义,通过make_move_iterator可避免拷贝、提升性能;推荐日常使用insert()方法,简洁高效。

在C++中,将一个vector的内容添加到另一个vector中,也就是合并两个向量,有多种实现方式。最常用的方法是使用insert()函数或std::copy结合插入迭代器。下面介绍几种实用且高效的实现方法。
这是最直接、最常用的方式。vector::insert()可以在指定位置插入另一个vector的所有元素。
#include <vector>
#include <iostream>
int main() {
std::vector<int> vec1 = {1, 2, 3};
std::vector<int> vec2 = {4, 5, 6};
// 将vec2的所有元素插入到vec1末尾
vec1.insert(vec1.end(), vec2.begin(), vec2.end());
for (int i : vec1) {
std::cout << i << " ";
}
// 输出: 1 2 3 4 5 6
return 0;
}
这种方式简洁高效,适用于大多数场景。注意,vec1.end()表示插入位置,即在vec1的末尾追加。
如果想通过算法库的方式实现,可以使用std::copy配合std::back_inserter。
立即学习“C++免费学习笔记(深入)”;
示例代码:
#include <vector>
#include <algorithm>
#include <iterator>
#include <iostream>
int main() {
std::vector<int> vec1 = {1, 2, 3};
std::vector<int> vec2 = {4, 5, 6};
std::copy(vec2.begin(), vec2.end(), std::back_inserter(vec1));
for (int i : vec1) {
std::cout << i << " ";
}
// 输出: 1 2 3 4 5 6
return 0;
}
这种方法利用了标准算法,逻辑清晰,但性能略低于insert(),因为每次插入都可能触发动态增长检查。
对于初学者来说,使用范围for循环更易理解。
示例代码:
for (const auto& item : vec2) {
vec1.push_back(item);
}
这种方式可读性强,但在大量数据时效率不如insert(),因为没有预分配空间。若想优化,可在循环前调用vec1.reserve(vec1.size() + vec2.size())。
如果你不再需要源vector,可以考虑移动其内容以提升性能。
例如:
vec1.insert(vec1.end(), std::make_move_iterator(vec2.begin()),
std::make_move_iterator(vec2.end()));这会将vec2中的元素“移动”到vec1,避免不必要的拷贝,适用于大型对象。
基本上就这些常见方式。日常开发中推荐使用insert(),它简洁、高效、易维护。
以上就是c++++如何将一个vector的内容添加到另一个vector_C++合并两个向量的实现方式的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号