std::vector 两种操作的比较
来源:互联网 发布:企业淘宝开店流程 编辑:程序博客网 时间:2024/05/16 15:59
- swap
- assign
这里只想说明这三种操作的用处和效率。swap和assign都可以用在将一个vector的内容全部复制给另外一个vector,区别是swap会改变源vector,而assign会清空目的vector后再将源vector的值全部插入到目的vector中。就效率而言,swap只是交换vector的头指针,时间复杂度是常数;而assigin时间复杂度则是线性。
#include <vector>#include "DebugUtility.h"#include <iostream>#include <algorithm>#include <string>using namespace std;void print(int x){ cout << x << endl;}void Swap(vector<string>& source, vector<string>& dest){ DebugUtility temp; dest.swap(source);}void Assign(vector<string>& source, vector<string>& dest){ DebugUtility temp; dest.assign(source.begin(), source.end());}int main(int argc, const char *argv[]){ vector<string> source(900000, "90"); vector<string> destination(1, "abc"); Swap(source, destination); //source.clear(); //for_each(destination.begin(), destination.end(), print); //Assign(source, destination); //source.clear(); //for_each(destination.begin(), destination.end(), print); return 0;}
结果:
Total time elapsed : 1 us900000Total time elapsed : 12391 us900000
DebugUtility.h 大家可以从https://github.com/TimBao/Material.git/Utility取得。
- std::vector 两种操作的比较
- std::vector的几种遍历方式比较
- std::vector的几种遍历方式比较
- std::vector的几种遍历方式比较
- std vector与std list的效率比较
- std vector与std list的效率比较
- Vector两种插入数据的方法比较
- vector 访问元素的两种方法比较
- std::vector与std::list的执行速度比较 (C/C++) (STL)
- std::vector与std::list的执行速度比较 (C/C++) (STL)
- std::vector与std::list的执行速度比较 (C/C++) (STL)
- std::vector与std::list的执行速度比较 (C/C++) (STL)
- std::vector与std::list的执行速度比较 (C/C++) (STL)
- std::vector与std::list的执行速度比较 (C/C++) (STL)
- std::vector的排序
- std::vector到std::string的转换
- std::vector,std::deque,std::list的区别的使用
- std::set, std::list, std::vector在erase的区别
- MFC 如何添加位图按钮
- 游戏框架设计
- select低级错误
- java程序中加入@SuppressWarnings("serial")是什么意思?
- 黑马程序员_Map集合学习笔记
- std::vector 两种操作的比较
- 宏和枚举的区别
- PC电脑和Android模拟器访问及模拟器之间tcp/udp通信
- asp.net menu控件的那个黑色小三角箭头怎么去掉?
- Java开发中的23种设计模式详解
- outlook2007提示禁止访问下列具有潜在不安全因素的附件,如何解决
- 黑马程序员——java接口
- linux设备驱动模型浅析3--设备热插拔的支持
- Reverse Shell Cheat Sheet