最近接触到c++的vector,感觉很方便,之前参加了一些竞赛,涉及到一些算法的时候,一直觉得代码写的很冗余,很长的一段。C++的vector就可以解决这个问题,使用起来很方便。
之前我们写数组都是int array[]的形式,但是去遍历数组的时候总是要知道数组的大小才行,另外删除和插入数据时操作十分的繁琐,虽然可以也可以去用链表存,但是我们还是喜欢简单的方法,链表实在是比较麻烦….
现在有了容器以后,只需要vector<int > v;
如果需要添加元素的话 只需要v.push_back();即可
如果需要删除数组的元素的话,使用v.erase(v.begin()+1); 删除的是第一个元素(但其实是第二个元素了,它也是从0开始计的(0,1,2……) )我下面说的第几个,都是指从0开始的。
另外,它可以删除一段区间的所有元素。v.erase(v.begin()+1,v.begin()+5); 删除的是下标1,2,3,4的元素。并没有删除下标为5的元素,这一点需要注意!删除的是到v.begin()+5前一个元素为止的。
插入元素的话 使用v.insert(v.begin(),1);在第零个元素前面插1
v.insert(v.begin()+2,2);在第二个元素前插2
v.insert(v.end(),1000);注意 这个是在最后一个元素后面插的1000,而并不是最后一个的前面。大家可以自己自己试试。
另外在这里讲一下遍历。vector<int>::iterator it; it
for(it=v.begin();it!=v.end();it++)
cout<<*it<<' ';
cout<<endl;
这样就可以遍历整个数组了,我c++的语法也有点忘记了,但是这里的it无非就是一个指针,暂且不去细究这个语法。
v.size();元素的个数
v.clear();清除所有元素
需要头文件#include<vector>
1 #include<iostream>
2 #include<vector>
3 using namespace std;
4 int main()
5 {
6 vector<int>::iterator it;
7 vector<int > v;
8 int i;
9 for(i=0;i<10;i++)//添加10个元素 1,2,3....
10 {
11 v.push_back(i);
12 }
13
14 for(it=v.begin();it!=v.end();it++)//遍历一下整个数组
15 cout<<*it<<" ";
16 cout<<endl;
17
18 v.erase(v.begin()+1);//删除的是第一个元素(下标从0开始)
19 // 也就是1 ,所以现在是0,2,4...9
20 v.insert(v.begin()+1,1);//把删除的再加进去
21 v.erase(v.begin()+1,v.begin()+4);//删除的第1,2,3 的元素共三个元素
22 //也就是剩下的是 0,4,5,6,7,8,9
23 for(it=v.begin();it!=v.end();it++)//遍历一下整个数组
24 cout<<*it<<" ";
25 cout<<endl;
26
27 cout<<v.size()<<endl;//看一下数组的大小
28
29 v.clear();
30
31 cout<<v.size()<<endl;
32 return 0;
33
34
35
36
37
38 }