当前位置: 首页 > news >正文

C++中vector追加vector

在C++中,如果你想将一个vector追加到另一个vector的后面,可以使用std::vector的成员函数insert或者std::copy,或者简单地使用std::vector的push_back方法逐个元素添加。这里我将展示几种常用的方法:

方法1:使用insert方法
#include <vector>
#include <iostream>
 
int main() {
    std::vector<int> vec1 = {1, 2, 3};
    std::vector<int> vec2 = {4, 5, 6};
 
    // 使用insert方法,将vec2的所有元素插入到vec1的末尾
    vec1.insert(vec1.end(), vec2.begin(), vec2.end());
 
    // 打印vec1以验证结果
    for(int i : vec1) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
 
    return 0;
}
方法2:使用std::copy方法
#include <vector>
#include <algorithm> // 需要包含此头文件以使用std::copy
#include <iostream>
 
int main() {
    std::vector<int> vec1 = {1, 2, 3};
    std::vector<int> vec2 = {4, 5, 6};
 
    // 使用std::copy将vec2的所有元素复制到vec1的末尾
    std::copy(vec2.begin(), vec2.end(), std::back_inserter(vec1));
 
    // 打印vec1以验证结果
    for(int i : vec1) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
 
    return 0;
}
方法3:使用push_back方法逐个添加元素(效率较低)
#include <vector>
#include <iostream>
 
int main() {
    std::vector<int> vec1 = {1, 2, 3};
    std::vector<int> vec2 = {4, 5, 6};
 
    // 使用push_back逐个添加vec2的元素到vec1的末尾(效率较低)
    for(int i : vec2) {
        vec1.push_back(i);
    }
 
    // 打印vec1以验证结果
    for(int i : vec1) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
 
    return 0;
}
方法4:使用范围for循环(简洁但不推荐用于大量数据)
#include <vector>
#include <iostream>
#include <algorithm> // 可能需要包含此头文件以使用std::copy_if(此处仅为示例,实际上不需要)
 
int main() {
    std::vector<int> vec1 = {1, 2, 3};
    std::vector<int> vec2 = {4, 5, 6};
    // 使用范围for循环(不推荐,仅用于演示)
    for (auto& elem : vec2) {
        vec1.push_back(elem); // 直接在循环内push_back可能导致效率问题,特别是对于大量数据。更推荐前三种方法。
    }
    // 打印vec1以验证结果(同上)
    for(int i : vec1) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    return 0;
}

通常,推荐使用insert方法或std::copy方法,因为它们在内部实现上通常更高效,尤其是在处理大量数据时。而使用push_back逐个添加元素在处理大量数据时可能会比较低效,因为它涉及到多次内存分配和拷贝。

http://www.lryc.cn/news/529853.html

相关文章:

  • 加一(66)
  • 远程连接-简化登录
  • canvas的基本用法
  • Tailwind CSS - Tailwind CSS 引入(安装、初始化、配置、引入、构建、使用 Tailwind CSS)
  • 鸿蒙开发黑科技“stack叠层”替代customdialog
  • FreeRTOS从入门到精通 第十五章(事件标志组)
  • 智慧园区管理平台实现智能整合提升企业运营模式与管理效率
  • markdown公式特殊字符
  • 【深度分析】微软全球裁员计划不影响印度地区,将继续增加当地就业机会
  • 学习数据结构(5)单向链表的实现
  • 刷题记录 HOT100回溯算法-5:22. 括号生成
  • Keepalived高可用集群企业应用实例二
  • C++计算特定随机操作后序列元素乘积的期望
  • c++字母大小写转换
  • MySQL知识点总结(十六)
  • Windows程序设计10:文件指针及目录的创建与删除
  • geolocator包的功能和用法
  • Node.js——body-parser、防盗链、路由模块化、express-generator应用生成器
  • 22.Word:小张-经费联审核结算单❗【16】
  • Agent 高频知识汇总:查漏补缺参考大全
  • 本地化部署DeepSeek-R1
  • 验证二叉搜索数(98)
  • StarRocks BE源码编译、CLion高亮跳转方法
  • 数模测评:doubao1.5>deepseek-v3>gpt-o1
  • 晴,初三,年已过
  • Vue3 v-bind 和 v-model 对比
  • Smalltalk语言是何物?面向对象鼻祖Simula的诞生?Simula和Smalltalk有什么区别?面向对象设计?
  • KVM/ARM——基于ARM虚拟化扩展的VMM
  • Windows系统中Docker可视化工具对比分析,Docker Desktop,Portainer,Rancher
  • 【架构面试】二、消息队列和MySQL和Redis