程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 更多關於編程 >> C++中vector的用法小結

C++中vector的用法小結

編輯:更多關於編程

     這篇文章主要介紹了c++中,vector是一個十分有用的容器,下面對這個容器做一下總結 

    1 基本操作   (1)頭文件#include<vector>.   (2)創建vector對象,vector<int> vec;   (3)尾部插入數字:vec.push_back(a);   (4)使用下標訪問元素,cout<<vec[0]<<endl;記住下標是從0開始的。   (5)使用迭代器訪問元素.     代碼如下: vector<int>::iterator it; for(it=vec.begin();it!=vec.end();it++)     cout<<*it<<endl;     (6)插入元素:    vec.insert(vec.begin()+i,a);在第i+1個元素前面插入a;   (7)刪除元素:    vec.erase(vec.begin()+2);刪除第3個元素   vec.erase(vec.begin()+i,vec.end()+j);刪除區間[i,j-1];區間從0開始   (8)向量大小:vec.size();   (9)清空:vec.clear();   2   vector的元素不僅僅可以使int,double,string,還可以是結構體,但是要注意:結構體要定義為全局的,否則會出錯。下面是一段簡短的程序代碼:      代碼如下: #include<stdio.h> #include<algorithm> #include<vector> #include<iostream> using namespace std;   typedef struct rect {     int id;     int length;     int width;     //對於向量元素是結構體的,可在結構體內部定義比較函數,下面按照id,length,width升序排序。   bool operator< (const rect &a)  const     {         if(id!=a.id)             return id<a.id;         else         {             if(length!=a.length)                 return length<a.length;             else                 return width<a.width;         }     } }Rect;   int main() {     vector<Rect> vec;     Rect rect;     rect.id=1;     rect.length=2;     rect.width=3;     vec.push_back(rect);     vector<Rect>::iterator it=vec.begin();     cout<<(*it).id<<' '<<(*it).length<<' '<<(*it).width<<endl;       return 0;   }     3  算法   (1) 使用reverse將元素翻轉:需要頭文件#include<algorithm>   reverse(vec.begin(),vec.end());將元素翻轉(在vector中,如果一個函數中需要兩個迭代器,   一般後一個都不包含.)   (2)使用sort排序:需要頭文件#include<algorithm>,   sort(vec.begin(),vec.end());(默認是按升序排列,即從小到大).   可以通過重寫排序比較函數按照降序比較,如下:   定義排序比較函數:     復制代碼 代碼如下: bool Comp(const int &a,const int &b) {     return a>b; }   調用時:sort(vec.begin(),vec.end(),Comp),這樣就降序排序。
    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved