亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++入門筆記之std::vector容器詳解

 更新時間:2021年07月06日 11:16:39   作者:Code_DZhangTeng  
這篇文章主要給大家介紹了關(guān)于C++之std::vector容器的相關(guān)資料,vector,一種隨機(jī)訪問的數(shù)組類型,它提供了對數(shù)組元素的快速、隨機(jī)訪問,以及在序列尾部快速、隨機(jī)的插入和刪除操作,需要的朋友可以參考下

前言

vector實(shí)質(zhì)是C++的一個類,與數(shù)組很相似,但是vector的優(yōu)勢是可以動態(tài)擴(kuò)展,不需要考慮其內(nèi)存大小。

定義:

向量(Vector)是一個封裝了動態(tài)大小數(shù)組的順序容器(Sequence Container)。跟任意其它類型容器一樣,它能夠存放各種類型的對象。可以簡單的認(rèn)為,向量是一個能夠存放任意類型的動態(tài)數(shù)組。

特性:

1.順序序列

順序容器中的元素按照嚴(yán)格的線性順序排序??梢酝ㄟ^元素在序列中的位置訪問對應(yīng)的元素。

2.動態(tài)數(shù)組

支持對序列中的任意元素進(jìn)行快速直接訪問,甚至可以通過指針?biāo)闶鲞M(jìn)行該操作。操供了在序列末尾相對快速地添加/刪

除元素的操作。

3.能夠感知內(nèi)存分配器的(Allocator-aware)

容器使用一個內(nèi)存分配器對象來動態(tài)地處理它的存儲需求。

1. vector的構(gòu)造函數(shù)原型:

    vector<T> data; //使用模板類,默認(rèn)構(gòu)造函數(shù)

    vector(data.begin(),data.end()); //將data的【begin(),end())區(qū)間中的元素拷貝給本身,注意是數(shù)學(xué)中的前閉后開 區(qū)間

    vector(n,elem); //將n個elem元素拷貝給本身

    vector(const vector &data); //拷貝構(gòu)造

#include <iostream>
#include <vector>
 
using namespace std;
 
void fun_print_vector(std::vector<int>&data)
{
    //std::vector<int>::iterator it; //可以用auto代替。
    for(auto it_data = data.begin();it_data != data.end();it_data++){
        std::cout << *it_data << " " << std::endl;
    }
}
void fun_vector()
{
    vector<int> data1; //默認(rèn)構(gòu)造
    data1.push_back(1);
    data1.push_back(2);
    data1.push_back(3);
    fun_print_vector(data1); //打?。? 2 3 
 
    vector<int> data2(data1.begin(),data1.end()); //通過區(qū)間進(jìn)行構(gòu)造
    fun_print_vector(data2); //打?。? 2 3 
 
    vector<int> data3(4,1);//4個1構(gòu)造
    fun_print_vector(data3); //打?。? 1 1 1 
 
    vector<int> data4(data3); //拷貝構(gòu)造
    fun_print_vector(data4); //打印:1 1 1 1 
 
}

2. vector的賦值函數(shù)原型:

vector& operator=(cost vector &data); //重載操作符

vector& assign(beg,end); //將[ beg,ed )區(qū)間中的數(shù)據(jù)拷貝賦值給本身

vector& assign(n,elem); //將n個elem拷貝賦值給本身

#include <iostream>
#include <vector>
 
using namespace std;
 
void fun_print_vector(std::vector<int>&data)
{
    //std::vector<int>::iterator it; //可以用auto代替。
    for(auto it_data = data.begin();it_data != data.end();it_data++){
        std::cout << *it_data << " " << std::endl;
    }
}
void fun_vector()
{
    vector<int> data1;
    for(int i = 0;i < 6;i++){
        data1.push_back(i);
    }
    fun_print_vector(data1); //打印 0 1 2 3 4 5
 
    vector<int> data2;
    data2 = data1;
    fun_print_vector(data2); //打印 0 1 2 3 4 5
 
    vector<int> data3;
    data3.assign(data1.begin(),data1.end());
    fun_print_vector(data3); //打印 0 1 2 3 4 5
 
    vector<int> data4;
    data3.assign(3,6);
    fun_print_vector(data4); //打印 6 6 6
}

3. vector的容量和大小函數(shù)原型:

empty(); //判斷容器是否為空

capacity(); //容器的容量    capacity一定會大于等于size

size(); //返回容器中元素的個數(shù)

resize(int num); //重新指定容器的長度為num,若容器變長,則以默認(rèn)值填充新的位置;若容器變短,則末尾超出的元素被刪除

resize(int num,elem); //重新指定容器的長度為num,若容器變長,則以elem數(shù)值填充新的位置;若容器變短,則末尾超出的元素被刪除

#include <iostream>
#include <vector>
 
using namespace std;
 
void fun_print_vector(std::vector<int>&data)
{
    //std::vector<int>::iterator it; //可以用auto代替。
    for(auto it_data = data.begin();it_data != data.end();it_data++){
        std::cout << *it_data << " " << std::endl;
    }
}
void fun_vector()
{
    vector<int> data1;
    for(int i = 0;i < 6;i++){
        data1.push_back(i);
    }
    fun_print_vector(data1); //打印 0 1 2 3 4 5
 
    if(data1.empty() == true){
        std::cout << "該容器是空" << std::endl;
    }else{
        std::cout << "該容器不是空" << std::endl;
        std::cout << "data1.capacity:" << data1.capacity() << std::endl;
        std::cout << "data1.size:" << data1.size() << std::endl;
    }
    data1.resize(10); //填充默認(rèn)值0
    fun_print_vector(data1); //打印 0 1 2 3 4 5 0 0 0 0
    data1.resize(13,8); //填充數(shù)值8
    fun_print_vector(data1); //打印 0 1 2 3 4 5 0 0 0 0 8 8 8
    data1.resize(4);
    fun_print_vector(data1); //打印 0 1 2 3
}

4. vector的插入和刪除函數(shù)原型:

push_back(elem); //尾部插入元素elem

pop_back(); //刪除最后一個元素

insert(const_iterator pos, elem); //迭代器指向位置pos插入元素elem

insert(const_iterator pos, int count,elem); //迭代器指向位置pos插入count個元素elem

erase(const_iterator pos); //刪除迭代器指向的元素

erase(const_iterator start,const_iterator end); //刪除迭代器start到end之間的元素

clear(); //刪除容器中所有元素

#include <iostream>
#include <vector>
 
using namespace std;
 
void fun_print_vector(std::vector<int>&data)
{
    //std::vector<int>::iterator it; //可以用auto代替。
    for(auto it_data = data.begin();it_data != data.end();it_data++){
        std::cout << *it_data << " " << std::endl;
    }
}
void fun_vector()
{
    vector<int> data1;
    for(int i = 0;i < 6;i++){
        data1.push_back(i);
    }
    fun_print_vector(data1); //打印 0 1 2 3 4 5
    data1.pop_back(); //尾刪
    fun_print_vector(data1); //打印 0 1 2 3 4
    data1.insert(data1.begin(),22); //迭代器位置插入一個22
    fun_print_vector(data1); //打印 22 0 1 2 3 4
    data1.insert(data1.begin(),3,7); //迭代器位置插入三個22
    fun_print_vector(data1); //打印 7 7 7 22 0 1 2 3 4
 
    data1.erase(data1.begin()); //迭代器位置刪除
    fun_print_vector(data1); //打印 7 7 22 0 1 2 3 4
    data1.erase(data1.begin(),data1.end()); //迭代器位置 區(qū)間 刪除
    fun_print_vector(data1); //打印 空
 
    data1.clear(); //清空容器
    fun_print_vector(data1); //打印 空
 
}

5. vector的存取操作函數(shù)原型:

at(int idx); //返回索引idx所指的數(shù)據(jù)

operator []; //返回索引idx所指的數(shù)據(jù)

front(); //返回容器的第一個數(shù)據(jù)元素

back(); //返回容器的最后一個數(shù)據(jù)元素

#include <iostream>
#include <vector>
 
using namespace std;
 
void fun_print_vector(std::vector<int>&data)
{
    //std::vector<int>::iterator it; //可以用auto代替。
    for(auto it_data = data.begin();it_data != data.end();it_data++){
        std::cout << *it_data << " " << std::endl;
    }
}
void fun_vector()
{
    vector<int> data1;
    for(int i = 0;i < 6;i++){
        data1.push_back(i);
    }
 
    //利用[]方式訪問vector中的元素
    for(int j = 0;j<data1.size();j++){
        std::cout << data1[j] << " " << std::endl;
    }
    //利用at方式訪問vector中的元素
    for(int j = 0;j<data1.size();j++){
        std::cout << data1.at(j) << " " << std::endl;
    }
 
    std::cout << "第一個元素是:" << data1.front() << std::endl;
    std::cout << "最后一個元素是:" << data1.back() << std::endl;
 
}

6. vector的呼喚容器函數(shù)原型:

swap(vec); //將vecy與本身 兩個容器中的元素互換

#include <iostream>
#include <vector>
 
using namespace std;
 
void fun_print_vector(std::vector<int>&data)
{
    //std::vector<int>::iterator it; //可以用auto代替。
    for(auto it_data = data.begin();it_data != data.end();it_data++){
        std::cout << *it_data << " " << std::endl;
    }
}
void fun_vector()
{
    vector<int> data1;
    for(int i = 0;i < 6;i++){
        data1.push_back(i);
    }
    fun_print_vector(data1); //打印 0 1 2 3 4 5
 
    vector<int> data2;
    for(int i = 6;i > 0;i++){
        data2.push_back(i);
    }
    fun_print_vector(data2); //打印 6 5 4 3 2 1 
 
    data1.swap(data2);
    fun_print_vector(data1); //打印 6 5 4 3 2 1 
    fun_print_vector(data2); //打印 0 1 2 3 4 5 
 
}

總結(jié)

到此這篇關(guān)于C++入門筆記之std::vector容器的文章就介紹到這了,更多相關(guān)C++ std::vector容器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++基礎(chǔ)入門之運(yùn)算符

    C++基礎(chǔ)入門之運(yùn)算符

    下面小編就為大家?guī)硪黄P(guān)于C++運(yùn)算符基礎(chǔ)的文章。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-11-11
  • C語言之平衡二叉樹詳解

    C語言之平衡二叉樹詳解

    平衡二叉樹是具有平衡屬性的有序二叉樹,本文主要介紹了C語言中的平衡二叉樹,具有一定的參考價值,需要的小伙伴可以參考閱讀
    2023-04-04
  • c++?error:crosses?initialization?of問題解決分析

    c++?error:crosses?initialization?of問題解決分析

    這篇文章主要介紹了c++?error:crosses?initialization?ofde?問題解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • 超詳細(xì)講解C++的三種函數(shù)傳遞方式

    超詳細(xì)講解C++的三種函數(shù)傳遞方式

    這個文章我將把我學(xué)習(xí)的有關(guān)函數(shù)傳遞形式的知識做個總結(jié),相信很多剛?cè)腴T的同學(xué)看到許多文章五花八門的形參會感到頭疼,但本質(zhì)上無非就是我要說的三種傳遞形式,快來跟我一起學(xué)習(xí)吧
    2022-05-05
  • 從頭學(xué)習(xí)C語言之switch語句和分支嵌套

    從頭學(xué)習(xí)C語言之switch語句和分支嵌套

    這篇文章主要為大家詳細(xì)介紹了C語言之switch語句和分支嵌套,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • C++中對象的常引用、動態(tài)建立和釋放相關(guān)知識講解

    C++中對象的常引用、動態(tài)建立和釋放相關(guān)知識講解

    這篇文章主要介紹了C++中對象的常引用、動態(tài)建立和釋放相關(guān)知識講解,是C++入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-09-09
  • C++智能指針模板應(yīng)用詳細(xì)介紹

    C++智能指針模板應(yīng)用詳細(xì)介紹

    從比較簡單的層面來看,智能指針是RAII(Resource Acquisition Is Initialization,資源獲取即初始化)機(jī)制對普通指針進(jìn)行的一層封裝。這樣使得智能指針的行為動作像一個指針,本質(zhì)上卻是一個對象,這樣可以方便管理一個對象的生命周期
    2022-08-08
  • C++哈希表之線性探測法實(shí)現(xiàn)詳解

    C++哈希表之線性探測法實(shí)現(xiàn)詳解

    線性探測法的優(yōu)點(diǎn):只要散列表未滿,總能找到一個不沖突的散列地址;缺點(diǎn):每個產(chǎn)生沖突的記錄被散列到離沖突最近的空地址上,從而又增加了更多的沖突機(jī)會
    2022-05-05
  • C++實(shí)現(xiàn)圖書信息管理系統(tǒng)

    C++實(shí)現(xiàn)圖書信息管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)圖書信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 求32位機(jī)器上unsigned int的最大值及int的最大值的解決方法

    求32位機(jī)器上unsigned int的最大值及int的最大值的解決方法

    本篇文章是對求32位機(jī)器上unsigned int的最大值及int的最大值的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05

最新評論