1. //比较数组、vector、array
  2. #include <iostream>
  3. #include <vector>
  4. #include <array>
  5. #include <iomanip>
  6. using namespace std;
  7. int main(void)
  8. {
  9. /*1.构造方式
  10. * vector:有多种构造方式,不需要定义元素个数;除常见的初始化方式外,还可以
  11. * 通过vector和数组构造新的vector
  12. * array:定义时必须指定array的大小,可通过array构造新的array,不可使用数组构造
  13. * 数组:定义时必须指定array的大小,使用{}初始化
  14. */
  15. vector<int> myvector = {1,2,3,4,5};
  16. array<int, 5> myarray = {1,2,3,4,5};
  17. int myint[5] = { 1, 2, 3, 4, 5 };
  18. /*2.访问方式
  19. * 三者均可通过下标运算符[]对元素进行操作,vector和array还可以通过at/front/back进行操作
  20. */
  21. cout << setw(10) << "vector" << setw(10) << "array" << setw(10) << "数组" << endl;
  22. for (int i = 0; i < 5; i++)
  23. {
  24. cout << setw(10) << myvector.at(i) << setw(10) << myarray.at(i) << setw(10) << myint[i] << endl;
  25. }
  26. /*3.遍历方式
  27. * vector和array还可以通过正向和反向迭代器对元素进行遍历
  28. */
  29. cout << "=============正向迭代器遍历=========="<< endl;
  30. for (vector<int>::iterator it = myvector.begin(); it != myvector.end();++it)
  31. {
  32. cout << *it << endl;
  33. }
  34. cout << "=============反向迭代器遍历==========" << endl;
  35. for (vector<int>::reverse_iterator it = myvector.rbegin(); it != myvector.rend(); ++it)
  36. {
  37. cout << *it << endl;
  38. }
  39. /*4.增删元素
  40. * vector可以通过push_back/pop_back/emplace/emplace_back/insert动态增删元素
  41. * array和数组无法实现动态增删元素
  42. */
  43. myvector.push_back(6);
  44. myvector.emplace_back(7);
  45. vector<int>::iterator it = myvector.end();
  46. myvector.insert(it, { 8, 9 });//在尾部插入元素,可通过it改变插入位置,也可以插入多个元素
  47. myvector.pop_back();
  48. cout << "=============动态增删元素==========" << endl;
  49. for (vector<int>::iterator it = myvector.begin(); it != myvector.end(); ++it)
  50. {
  51. cout << *it << endl;
  52. }
  53. return 0;
  54. }

vector以及array和数组的更多相关文章

  1. c++ 的vector、array和数组的比较

    ref:  http://blog.csdn.net/haust_wang/article/details/49848169

  2. [CareerCup] 17.6 Sort Array 排列数组

    17.6 Given an array of integers, write a method to find indices m and n such that if you sorted elem ...

  3. Vector, ArrayList, Array

    JAVA新手在使用JAVA的时候大概都会遇到这个问题: JAVA中的Array, ArrayList, Vector, List, LinkedList有什么样的区别?尤其是Vector, Array ...

  4. C++ vector 实现二维数组

    在STL中Vector这一容器,无论是在封装程度还是内存管理等方面都由于传统C++中的数组.本文主要是关于使用Vector初始化.遍历方面的内容.其他二维的思想也是类似的. 这里简单叙述一下C++ 构 ...

  5. vector创建2维数组

    以前我要建立一个二维数组,总是使用 int N=5, M=6; vector<vector<int> > Matrix(N); for(int i =0; i< Matr ...

  6. Vector 和 Array 区别

    1:array 定义的时候必须定义数组的元素个数;而vector 不需要:且只能包含整型字面值常量,枚举常量或者用常量表达式初始化的整型const对象, 非const变量以及需要到运行阶段才知道其值的 ...

  7. C++标准库分析总结(四)——<Vector、Array、Forward_list设计原则>

    本节主要总结标准库Vector和Array的设计方法和特性以及相关迭代器内部特征 1.Vector 1.1 Vector 内部实现 Vector是自增长的数组,其实在标准库中没有任何一种容器能原地扩充 ...

  8. ArrayList、LinkedList、Vector、Array和HashMap、HashTable

    就 ArrayList 与 Vector 主要从二方面来说. 一.同步性:Vector 是线程安全的,也就是说是同步的,而ArrayList 是线程序不安全的,不是同步的 二.数据增长:当需要增长时, ...

  9. Namespace, string, vector and array

    1. Headers should not include using declaration Code inside headers ordinarily should not include us ...

随机推荐

  1. 【JZOJ6354】最短路(tiring)

    description analysis 显然边权有变化规律\(x,{1\over{x-1}},{x-1\over x},x,...\) 于是把一个点拆成三个点,分别表示步数到除\(3\)余\(0,1 ...

  2. QQ空间删除日志

    按下F12,贴上如下代码 var delay = 2000; function del() { document.querySelector(".app_canvas_frame" ...

  3. 「题解」:$Simple$

    问题 A: $Simple$ 时间限制: 1 Sec  内存限制: 256 MB 题面 题面谢绝公开. 题解 不算数学的数学题?? 直接枚举会重.$60%$两种算法:1.无脑$vis$数组记录.2.$ ...

  4. 训练计划Day1

    Day1:二分答案,三分查找,快速幂,欧拉筛素数 | 题目:火星人,Bridge,GCD,Prime Path 二分答案 [JSOI 2008] 火星人 对于第一个操作用\(hash + 二分\)来求 ...

  5. XML、JSON、ProtocolBuffer特点比较

    XML JSON PB Lua 数据结构支持 复杂结构 简单结构 较复杂结构 复杂结构 数据保存方式 文本 文本 二进制 文本 数据保存大小 大 一般 小 一般 解析效率 慢 一般 快 稍快 语言支持 ...

  6. "一个实用的却被忽略的命名空间:Microsoft.VisualBasic":

        当你看到这个命名空间的时候,别因为是vb的东西就匆忙关掉网页,那将会是您的损失,此命名空间中的资源最初目的是为了简化vb.net开发而创建的,所以microsoft.visualbasic并不 ...

  7. error C2872: 'ULONG_PTR' : ambiguous symbol

    转自VC错误:http://www.vcerror.com/?p=74 问题描述: 错误:error C2872: 'ULONG_PTR' : ambiguous symbol 解决方法: 详细的解决 ...

  8. PAT甲级——A1107 Social Clusters

    When register on a social network, you are always asked to specify your hobbies in order to find som ...

  9. java笔试之完全数计算

    完全数(Perfect number),又称完美数或完备数,是一些特殊的自然数. 它所有的真因子(即除了自身以外的约数)的和(即因子函数),恰好等于它本身. 例如:28,它有约数1.2.4.7.14. ...

  10. thinkphp 区间查询

    ThinkPHP支持对某个字段的区间查询,例如: 富瑞华大理石平台厂家哪家好 $map['id'] = array(array('gt',1),array('lt',10)) ; 得到的查询条件是:  ...