std::vector<int> demo{1,2};//第一种格式用法demo.insert(demo.begin() +1,3);//{1,3,2}//第二种格式用法demo.insert(demo.end(),2,5);//{1,3,2,5,5}//第三种格式用法std::array<int,3>test{7,8,9}; demo.insert(demo.end(), test.begin(),
1.1 vector(数组)封装动态数组的顺序容器。 1.2 queue(队列)是容器适配器,他是FIFO(先进先出)的数据结构。 1.3 deque(双端队列)是有下标顺序容器,它允许在其首尾两段快速插入和删除。 1.4 set(集合)集合基于红黑树实现,有自动排序的功能,并且不能存放重复的元素。 1.5 unordered_set(无序集合)基于哈希表实现,...
STL——vector常用操作 c.assign(beg,end) c.assign(n,elem) 将(beg; end)区间中的数据赋值给c。将n个elem的拷贝赋值给c。 c. at(idx) 传回索引idx所指的数据,如果idx越界,抛出out_of_range。 c.back() 传回最后一个数据,不检查这个数据是否存在。 c.begin() 传回迭代器中的第一个数据地址。 c.c...
1.vector<数据类型> 函数名; 初始化为空 2.vector<数据类型> 函数名(a,b).定义a个空间,都初始化为b。 3.vector<数据类型> 函数名1=函数名2. 把动态数组2复制给动态数组1。 4.vector<数据类型> 函数名1(函数名2.begin(),函数名2.end()). 把动态数组2复制给动态数组1。 5.vector<数据类型> 函数...
begin(); it != v.end(); it++){ if (*it == 0){ v.insert(it, 11); break; } } for (vector<int>::size_type ix = 0; ix != v.size(); ix ++){ printf("%d\t", v[ix]); } printf("\n"); return 0; } 2.2、删除操作 使用erase()方法删除指定的元素。 代码语言:...
1.1、定义空的vector 定义的方法为: vector<T> v; 1. 1.2、定义一个vector的副本 定义的方法为: vector<T> v1(v); 1. 1.3、定义并初始化 定义的方法为: vector<T> v2(n, i); 1. 定义了长度为n的vector v2,并且每个元素都是i。 1.4、定义并指定初始长度 ...
class vector { public: typedef T* iterator; private: iterator _start; // 开始位置 iterator _finish; // 结束位置 iterator _eos; // end of storage }; } 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16.
vector<int>::iterator it;//C98标准 for(it=v.begin();it!=v.end();it++){ cout<<*it<<' '; } 当然,遍历也可以直接使用下标访问: 1 2 3 for(inti=0;i<v.size();i++){ cout<<v[i]<<' '; } 请根据自己的使用习惯进行合理的安排,对于新手而言会更倾向于选择后者。
在C语言中,vector是一种动态数组,可以根据需要自动调整大小。它提供了一组函数和操作符来管理和操作数组,使得数组的使用更加方便和灵活。在C语言中,要使用vector,首先需要包含头文件<vector.h>。然后可以使用以下方式定义和初始化一个vector:#include<stdio.h> #include<vector.h> intmain(){ vector<int>v;...
vector::iteratoritePre; cout<<"eraseVECinwrongway"<<endl; for(itePre=myVec.begin();itePre!=myVec.end();itePre++) { myVec.erase(itePre); } printVec(myVec); 按我以前的理解,这样的循环删除方式预期的结果应该是会把vector中的数据清空,但是事实并非如此事实会导致程序崩溃因为itePre迭代器本身...