c++中vector使用


最近接触到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 }

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM