vector以及array和数组

- //比较数组、vector、array
- #include <iostream>
- #include <vector>
- #include <array>
- #include <iomanip>
- using namespace std;
- int main(void)
- {
- /*1.构造方式
- * vector:有多种构造方式,不需要定义元素个数;除常见的初始化方式外,还可以
- * 通过vector和数组构造新的vector
- * array:定义时必须指定array的大小,可通过array构造新的array,不可使用数组构造
- * 数组:定义时必须指定array的大小,使用{}初始化
- */
- vector<int> myvector = {1,2,3,4,5};
- array<int, 5> myarray = {1,2,3,4,5};
- int myint[5] = { 1, 2, 3, 4, 5 };
- /*2.访问方式
- * 三者均可通过下标运算符[]对元素进行操作,vector和array还可以通过at/front/back进行操作
- */
- cout << setw(10) << "vector" << setw(10) << "array" << setw(10) << "数组" << endl;
- for (int i = 0; i < 5; i++)
- {
- cout << setw(10) << myvector.at(i) << setw(10) << myarray.at(i) << setw(10) << myint[i] << endl;
- }
- /*3.遍历方式
- * vector和array还可以通过正向和反向迭代器对元素进行遍历
- */
- cout << "=============正向迭代器遍历=========="<< endl;
- for (vector<int>::iterator it = myvector.begin(); it != myvector.end();++it)
- {
- cout << *it << endl;
- }
- cout << "=============反向迭代器遍历==========" << endl;
- for (vector<int>::reverse_iterator it = myvector.rbegin(); it != myvector.rend(); ++it)
- {
- cout << *it << endl;
- }
- /*4.增删元素
- * vector可以通过push_back/pop_back/emplace/emplace_back/insert动态增删元素
- * array和数组无法实现动态增删元素
- */
- myvector.push_back(6);
- myvector.emplace_back(7);
- vector<int>::iterator it = myvector.end();
- myvector.insert(it, { 8, 9 });//在尾部插入元素,可通过it改变插入位置,也可以插入多个元素
- myvector.pop_back();
- cout << "=============动态增删元素==========" << endl;
- for (vector<int>::iterator it = myvector.begin(); it != myvector.end(); ++it)
- {
- cout << *it << endl;
- }
- return 0;
- }
vector以及array和数组的更多相关文章
- c++ 的vector、array和数组的比较
ref: http://blog.csdn.net/haust_wang/article/details/49848169
- [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 ...
- Vector, ArrayList, Array
JAVA新手在使用JAVA的时候大概都会遇到这个问题: JAVA中的Array, ArrayList, Vector, List, LinkedList有什么样的区别?尤其是Vector, Array ...
- C++ vector 实现二维数组
在STL中Vector这一容器,无论是在封装程度还是内存管理等方面都由于传统C++中的数组.本文主要是关于使用Vector初始化.遍历方面的内容.其他二维的思想也是类似的. 这里简单叙述一下C++ 构 ...
- vector创建2维数组
以前我要建立一个二维数组,总是使用 int N=5, M=6; vector<vector<int> > Matrix(N); for(int i =0; i< Matr ...
- Vector 和 Array 区别
1:array 定义的时候必须定义数组的元素个数;而vector 不需要:且只能包含整型字面值常量,枚举常量或者用常量表达式初始化的整型const对象, 非const变量以及需要到运行阶段才知道其值的 ...
- C++标准库分析总结(四)——<Vector、Array、Forward_list设计原则>
本节主要总结标准库Vector和Array的设计方法和特性以及相关迭代器内部特征 1.Vector 1.1 Vector 内部实现 Vector是自增长的数组,其实在标准库中没有任何一种容器能原地扩充 ...
- ArrayList、LinkedList、Vector、Array和HashMap、HashTable
就 ArrayList 与 Vector 主要从二方面来说. 一.同步性:Vector 是线程安全的,也就是说是同步的,而ArrayList 是线程序不安全的,不是同步的 二.数据增长:当需要增长时, ...
- Namespace, string, vector and array
1. Headers should not include using declaration Code inside headers ordinarily should not include us ...
随机推荐
- CSS——精灵技术
精灵技术产生的背景 图所示为网页的请求原理图,当用户访问一个网站时,需要向服务器发送请求,网页上的每张图像都要经过一次请求才能展现给用户. 然而,一个网页中往往会应用很多小的背景图像作为修饰,当网页中 ...
- CF Round #427 (Div. 2) C. Star sky [dp]
题目链接就长这样子? time limit per test 2 seconds memory limit per test 256 megabytes Description The Carte ...
- 关于merge的测试
测试多线程情况下merge是否能产生重复数据. merge并发测试: 测试代码: 100线程,,插入连续的1000个数字
- [HEOI 2018]一双木棋
题意:求对抗分数差值最大. 思路:状压dp,维护一条轮廓线,最大化分差.可以发现上一行的棋子个数永远比这一行多. #include<bits/stdc++.h> using namespa ...
- ICPC 2018 徐州赛区网络赛
ACM-ICPC 2018 徐州赛区网络赛 去年博客记录过这场比赛经历:该死的水题 一年过去了,不被水题卡了,但难题也没多做几道.水平微微有点长进. D. Easy Math 题意: ...
- git工作区和暂存区图
- webjars和springboot热启动
webjars WebJars将Web前端Javascript和CSS等资源打包成Java的Jar包, 以便能使Maven的依赖管理支持静态JavaScript库/CSS库,比如jQuery.layu ...
- JQ实现全选、全不选
代码: <table class="table myTable table-hover"> <thead> <tr> <th> &l ...
- Java基础 ----- 判断对象的类型
1. 判断对象的类型:instanceOf 和 isInstance 或者直接将对象强转给任意一个类型,如果转换成功,则可以确定,如果不成功,在异常提示中可以确定类型 public static vo ...
- HTML中被废弃的标签<b><u><i><s>
<strong>代替<b>给文字加粗 <ins>代替<u>给文本添加下划线 <em>代替<i>将文本倾斜 <del> ...