Ø vector和string一样,长度、下标等类型是size_type,但是vector获取size_type时,需要指定类型,如vector<int>::size_type这样的方式 Ø vector的下标操作,例如v[i],只能用于操作已经存在的元素,可以进行覆盖、获取等,但是不能通过v[i++]这种方式来给一个vector容器添加元素,该功能需要用push_back操作完成,下标...
for (vector<int>::size_type ix = 0; ix != v.size(); ix ++){ printf("%d\t", v[ix]); } printf("\n"); printf("second: "); for (vector<int>::size_type ix1 = 0; ix1 != v1.size(); ix1 ++){ printf("%d\t", v1[ix1]); } printf("\n"); printf("third: ")...
vector<int> a;vector<int>b(a);vector<int>c(10,23);vector<string>s1(10,"null");vector<string>s2(10); vector<string> s3 = {10,"hi!"};// 重点关注vector<string> s4 = {"10","hi!"};// 重点关注pr_int_vector(a);pr_int_vector(b);pr_int_vector(c);pr_str_vector(s1);pr_s...
3.vector的简单属性 1.【动态数组的访问下标】 函数名[n], n就是访问第几个元素 2.【动态数组的访问at函数】 函数名.at(n), n就是访问第几个元素 3.【动态数组的长度】 函数名.size(), 获取长度 4.【获取动态数组第一个元素】 函数名.front() ...
1.1 vector(数组)封装动态数组的顺序容器。 1.2 queue(队列)是容器适配器,他是FIFO(先进先出)的数据结构。 1.3 deque(双端队列)是有下标顺序容器,它允许在其首尾两段快速插入和删除。 1.4 set(集合)集合基于红黑树实现,有自动排序的功能,并且不能存放重复的元素。 1.5 unordered_set(无序集合)基于哈希表实现,...
表现在第一行打印上就是p解引用的下标与vector数组的相同下标的值是相同的;第二行的打印则表现出了对于指针p的解引用赋值直接将vector数组相同下标的值修改了。这就是所说的指针与一维数组的数组名(首地址)的等效,实际上二者还是有不同的地方,这里就不做进一步的说明了,有兴趣的同学可以在课下去探索一下。...
vector<int>v(n);// 定义一个长度为n的数组,初始值默认为0,数组下标可以使用的范围[0, n - 1]vector<int>v(n,1);// v[0] 到 v[n - 1]所有的元素初始值均为1//注意:指定数组长度之后(指定长度后的数组就相当于正常的数组了) 第一个是定义了数组的长度,而第二个又给数组元素赋值了,应该是比较...
1. stl vector基本概念 stl vector是一个动态数组,其内部实现采用连续的内存空间存储元素。vector中的每个元素都可以通过下标进行访问,且vector支持快速的随机访问。vector还支持在尾部添加/删除元素,并可以动态扩展/缩小内部空间以适应元素数量的变化。2. stl vector初始化 在使用stl vector之前,需要先进行初始化。
voidpr_int_vector(vector<int>vec) { for(auto&v:vec) { cout<<v<<" "; } cout<<endl; } voidpr_str_vector(vector<string>vec) { for(auto&v:vec) { cout<<v<<" "; } cout<<endl; } intmain() { vector<int>a; vector<int>b(a); ...