初探Vector

C++ vector是什么?应该如何理解

转载地址:http://hi.baidu.com/phpok/item/b2df4db0ab6925f262388eab

最近有几个好友问到我C++中的vector到底怎么理解它,很多人没有接触过它。一时间都被搞的晕头转向。其实vector很好理解,它就是可以动态创建对象元素个数的数组。如果你不知道什么是数组那就别浪费时间看下去。因为在C++中数组元素个数的定义只能够使用常量值,或在编译时就可以获得的值。列如

const int ay=5;
int array[ay];

或者

int array[5];

不可以使用

int ay;
int array[ay];

这种定义的方式。所以,数组元素的个数在C++中除了使用NEW表达式(比较麻烦)之外是不可以动态定义的。那么如何解决这个问题呢。

C++推出了标准库vector

在使用它的时候需要首先引头文件

#include <vector>
using std::vector;

接下来用几个简单的列子来说明它和数组的区别。

01  /********************************************************************
02       创建时间:      2009/09/21 21:11
03       文件名称:      test1.cpp
04       文件后缀:      cpp
05       文件作者:      QianLiang
06  
07       =====================================================
08       功能说明:      说明什么是vector以及它与数组的区别
09       -----------------------------------------------------------------
10       其他说明:     
11   *********************************************************************/
12  #include <iostream>
13  #include <vector>
14  using namespace std;
15  
16  int main()
17   {
18      /* 数组:静态定义元素个数 */
19       const int ay=5;
20      int   array1[ay];
21  
22      /* vector:动态定义元素个数 */
23      int     vy;
24       cin>>vy;
25      vector<int>     ivec1(vy);
26  
27      /* 测试它们每个元素的默认值,这里假设上面的vy输入为5 */
28      for (int i=0;i<ay;++i)
29       {
30           cout<<"数组:\t"<<array1[i]<<endl; //它输出的全是随即数
31           cout<<"vector:\t"<<ivec1[i]<<endl;//它将全部元素初始化为0
32           cout<<endl;
33       }
34  
35      /* 测试他们的赋值安全性 */
36      int array2[6];
37      //array1=array2;    ←这条语句就是错误的.而
38      vector<int>     ivec2(3);
39       ivec1=ivec2; //这条语句是正确的因为它可以动态的确定元素个数
40  
41  
42      /* 仅仅以上三条测试就足以说明使用vector比数组要安全的多,
43          第一它是动态的管理元素个数,这就避免了许多越界问题的发生
44          第二当未对它们进行初始化操作的时候vector会自动为每个元素添加
45          该类型的安全默认值.这也避免了若干问题的发生.
46  
47       接下来看看vector的使用,它有4个构造函数
48       vector<T> v1;         ←vector保存类型为T的对象.默认构造函数v1为空
49       vector<T> v2(v1);     ←V2是V1的一个副本.
50       vector<T> v3(n,i);     ←v3包含n个值为i的元素.
51       vector<T> v4(n);     ←v4含有值初始化的元素的n个副本.*/
52  
53      /* vector的操作 */
54       cout<<ivec1.empty();//如果ivec1为空则返回true(1),否则返回false(0)
55       cout<<ivec1.size();//返回ivec1中元素的个数;
56       ivec1.push_back(t) //在ivec1的末尾增加一个值为t的元素.
57  
58      return 0;
59   }

什么时候使用vector什么时候使用数组呢?

**由于vector是标准库,而数组则是内置类型。所以如果你追求程序的执行效率的话那就用数组吧。
**可确定数组元素个数的时候尽量使用数组。
**对于指针以及NEW操作符迷糊的时候使用vector,因为它内置有内存管理器。

下面是一个关于vector的编程习题。

01  /********************************************************************
02       创建时间:      2009/09/21 21:18
03       文件名称:      习题3-13.cpp
04       文件后缀:      cpp
05       文件作者:      QianLiang
06  
07       =====================================================
08       功能说明:      读一组整数到vector对象,计算并输出每对相邻元素的和.如
09                    果读入元素个数为奇数,则提示用户最后有一个元素没有求和
10                    ,并输出其值.然后修改程序:首尾元素两两配对(第一个和最
11                    后一个,第二个和倒数第二个,以次类推),计算每对元素的和
12                    并输出.
13       -----------------------------------------------------------------
14       其他说明:     
15   *********************************************************************/
16  #include <iostream>
17  #include <vector>
18  using namespace std;
19  
20  int main()
21   {
22      vector<int>     ve;
23      int     a(0);
24       const    int     CI(2);
25  
26       cout<<"输入整数,程序计算它们相邻数的和.输入0时程序开始计算"<<endl;
27      /* 请求用户输入整数,每个数字为ve的一个元素,如果用户输入0
28          程序将停止请求*/
29      while (cin>>a && a!=0)
30       {
31           ve.push_back(a);
32       }
33  
34      /* 统计ve的元素个数减1后赋给变量b */
35      int b(ve.size()-1);
36  
37      /* 判断用户是否直接输入了0,或是键盘上的任意键 */
38      if (ve.size()==0)
39       {
40           cout<<"无元素"<<endl;
41       }
42  
43      /* 判断用户输入元素的个数是否为奇数 */
44      else if (ve.size()%CI != 0)
45       {
46          /* 判断用户是否只输入了一个数字 */
47          if (ve.size()==1)
48           {
49               cout<<"一个元素无法计算"<<endl;
50           }
51          else
52           {
53               cout<<"您输入的元素个数是奇数,最后一个数字无法相加"<<endl;
54              for (int i=0;i<b;i+=CI)
55               {
56                   cout<<"第"<<i+1<<"组数:"<<ve[i]+ve[i+1]<<endl;
57               }
58  
59               cout<<"您输入的最后一个元素为:"<<ve[b]<<endl;
60           }
61       }
62  
63      /* 判断用户输入的元素个数是否为偶数 */
64      else if (ve.size()%CI == 0)
65       {
66          for (int i=0;i<b;i+=CI)
67           {
68               cout<<"第"<<i+1<<"组数:"<<ve[i]+ve[i+1]<<endl;
69           }
70       }
71  
72      return     0;
73   }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值