注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

_

_

 
 
 

日志

 
 

C++ Vector用法深入剖析  

2013-02-23 00:53:09|  分类: 默认分类 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
C++ vector::push_back 用法剖析

 

C++编程语言中有一种叫做Vector的应用方法,它的作用在实际编程中是非常重要的。在这里我们将会为大家详细介绍一下C++ Vector的相关应用技巧及基本内容,希望能给大家带来一些帮助。

(1)vector< 类型 > 标识符 ;

(2)vector< 类型 > 标识符(最大容量) ;

(3)vector< 类型 > 标识符(最大容量,初始所有值);

(4) int i[4] = {12,3,4,5};

  1. vector< 类型 > vi(i , i+2); //得到i索引值为3以后的值 ;

(5)vector< vector<int> > //vi 定义2维的容器;记得一定要有空格,不然会报错

  1. vector< int > line
  2. // 在使用的时候一定要首先将vi个行进行初始化;
  3. for(int i = 0 ; i < 10 ; i ++)
  4. {
  5. vector.push_back(line);
  6. }
  7. /// 个人认为使用vector定义二维数组很好,
    因为是长度可以不预先确定。很好。

(6)C++ Vector排序

  1. vector< int > vi ;
  2. vi.push_back(1);
  3. vi.push_back(3);
  4. vi.push_back(0);
  5. sort(vi.begin() , vi.end()); /// /小到大
  6. reverse(vi.begin(),vi.end()) /// 从大道小

(7)顺序访问

  1. vector < int > vi ;
  2. for( int i = 0 ; i < 10 ; i ++)
  3. {
  4. vi.push_back(i);
  5. }
  6. for(int i = 0 ; i < 10 ; i ++) /// 第一种调用方法
  7. {
  8. cout <<vi[i] <<" " ;
  9. }
  10. for(vector<int>::iterator it = vi.begin() ;
  11. it !=vi.end() ; it++) ///第二种调用方法
  12. {
  13. cout << *it << " " ;
  14. }

(8)寻找

  1. vector < int > vi ;
  2. for( int i = 0 ; i < 10 ; i ++)
  3. {
  4. vector.push_back(i);
  5. }
  6. vector < int >::interator it = find(vi.begin() , vi.end,3) ;
  7. cout << *it << endl ; ///返回容器内找到值的位置。

(9)使用数组对C++ Vector进行初始化

  1. int i[10] ={1,2,3,4,5,6,7,78,8} ;
  2. ///第一种
  3. vector<int> vi(i+1,i+3); ///从第2个元素到第三个元素
  4. for(vector <int>::interator it = vi.begin() ;
  5. it != vi.end() ; it++)
  6. {
  7. cout << *it <<" " ;
  8. }

(10) 结构体类型

  1. struct temp
  2. {
  3. public :
  4. string str ;
  5. public :
  6. int id ;
  7. }tmp;

  8. int main()
  9. {
  10. vector <temp> t ;
  11. temp w1 ;
  12. w1.str = "Hellowor" ;
  13. w1.id = 1 ;
  14. t.push_back(t1);
  15. cout << w1.str << "," <<w1.id <<endl ;
  16. return 0 ;
  17. }

C++ Vector的基本介绍就为大家介绍到这里。

vector::push_back

public member function

void push_back ( const T& x );

Add element at the end

Adds a new element at the end of the vector, after its current last element. The content of this new element is initialized to a copy of x.
This effectively increases the vector size by one, which causes a reallocation of the internal allocated storage if the vector size was equal to the vector capacity before the call. Reallocations invalidate all previously obtained iterators, references and pointers.

Parameters
x
Value to be copied to the new element.
T is the first template parameter (the type of the elements stored in the vector).
Return value
none
If a reallocation happens, it is performed using Allocator::allocate(), which may throw exceptions (for the default allocator, bad_alloc is thrown if the allocation request does not succeed).
Example

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

// vector::push_back #include <iostream> #include <vector> using namespace std;  int main () {   vector<int> myvector;   int myint;    cout << "Please enter some integers (enter 0 to end):\n";    do {     cin >> myint;     myvector.push_back (myint);   } while (myint);    cout << "myvector stores " << (int) myvector.size() << " numbers.\n";    return 0; }

The example uses push_back to add a new element to the vector each time a new integer is read.

Complexity
Constant (amortized time, reallocation may happen).
See also

vector::pop_back
Delete last element (public member function)

vector::insert
Insert elements (public member function)

  评论这张
 
阅读(388)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017