欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++標準模板庫vector的常用操作

 更新時間:2018年12月21日 11:08:42   作者:蝸牛201  
今天小編就為大家分享一篇關(guān)于C++標準模板庫vector的常用操作,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

一:介紹

vector是C++標準模板庫,是一個容器,底層是數(shù)組,為連續(xù)內(nèi)存。

命名空間為std,所屬頭文件為<vector>   注意:不是<vector.h>

vector存儲數(shù)據(jù)時,會分配一個存儲空間,如果繼續(xù)存儲,該分配的空間已滿,就會分配一塊更大的內(nèi)存,把原來的數(shù)據(jù)復制過來,繼續(xù)存儲,這些性能也會一定程度上會有損耗

二:常用操作

容量:

  • a.vector大?。簐ector.size()
  • b.vector所占內(nèi)存實際大小:vector.capacity()

修改:

  • a.尾部添加元素:vector.push_back()
  • b.尾部刪除元素:vector.pop_back()
  • c.交換兩個vector元素:vector.swap()
  • d.清空vector元素:vector.clear()
  • e.刪除指定元素:vector.erase(it)

迭代器:

  • a.vector開始指針:vector.begin()
  • b.vector尾部指針:vector.end()   注:最后一個元素的下一個位置,類似為NULL,不是容器的最后一個元素

訪問元素:

  • a.下標訪問:vector[1]  //不檢查是否越界
  • b.at方法訪問:vector.at(1) //自動檢查是否越界,如越界會拋出異常
  • c.訪問第一個元素:vector.front()
  • d.訪問最后一個元素:vector.back()

三:存儲

簡單存儲

  //存儲方式1
  vector<int> v1(10);
  for (int i=0; i<10; i++)
  {
    v1[i] = i;
  }
  //存儲方式2
  vector<int> v2;
  for (int i=0; i<10; i++)
  {
    v2.push_back(i);
  }

存儲結(jié)構(gòu)體和結(jié)構(gòu)體指針

  struct Student
  {
    char name[32];
    int age;
  };
  //存儲結(jié)構(gòu)體
  vector<Student> vStu1;
  for (int i=0; i<10; i++)
  {
    Student stu;
    strcpy(stu.name, "woniu201");
    stu.age = 30 + i;
    vStu1.push_back(stu);
  }
  //存儲結(jié)構(gòu)體指針
  vector<Student*> vStu2;
  for (int i=0; i<10; i++)
  {
    Student* pStu = (Student*)malloc(sizeof(Student));
    strcpy(pStu->name, "woniu201"); 
    pStu->age = 30 + i; 
    vStu2.push_back(pStu); 
  }

四:vector遍歷

  vector<int> v;
  for (int i=0; i<100; i++)
  {
    v.push_back(i);
  }
  //遍歷方式1
  for (int i=0; i<100; i++)
  {
    int& a = v[i];
    printf("%d ", a);
  }
  //遍歷方式2
  for (vector<int>::iterator it = v.begin(); it != v.end(); it++)
  {
    int&a = *it;
    printf("%d ", a);
  }

五:排序

對vector整形進行排序

#include "stdlib.h"
#include <vector>
#include <algorithm>
using namespace std;
//升序比較函數(shù)
int compare1(const int &a, const int &b)
{
  return a < b;
}
//降序比較函數(shù)
int compare2(const int &a, const int &b)
{
  return a > b;
}
int main()
{
  vector<int> v;
  for (int i=0; i<10; i++)
  {
    v.push_back(rand() % 10);
  }
  //遍歷輸出
  printf("排序前數(shù)據(jù):");
  for (vector<int>::iterator it = v.begin(); it != v.end(); it++)
  {
    printf("%d ", *it);
  }
  //升序排序
  sort(v.begin(), v.end(), compare1);
  //遍歷輸出
  printf("\n升序后數(shù)據(jù):");
  for (vector<int>::iterator it = v.begin(); it != v.end(); it++)
  {
    printf("%d ", *it);
  }
  //降序排序
  sort(v.begin(), v.end(), greater<int>());
  //遍歷輸出
  printf("\n降序后數(shù)據(jù):");
  for (vector<int>::iterator it = v.begin(); it != v.end(); it++)
  {
    printf("%d ", *it);
  }
  getchar();
  return 1;
}

對存放類成員變量排序

#include <string>
#include <vector>
#include <algorithm>
using namespace std;
class Student {
public:  
  Student(string n, int c) :name(n), core(c) {}
  string  name;
  int    core;
};
//升序比較函數(shù)
bool compare1(const Student& s1, const Student& s2)
{
  return s1.core < s2.core;
}
//降序比較函數(shù)
bool compare2(const Student& s1, const Student& s2)
{
  return s1.core > s2.core;
}
int main()
{
  vector<Student> v;
  Student s1("aaaa", 97);
  Student s2("bbbb", 99);
  Student s3("cccc", 95);
  v.push_back(s1);
  v.push_back(s2);
  v.push_back(s3);
  printf("排序前數(shù)據(jù):\n");
  for (vector<Student>::iterator it = v.begin(); it != v.end(); it++)
  {
    printf("%s; %d\n", ((*it).name).c_str(), (*it).core);
  }
  //升序排序
  sort(v.begin(), v.end(), compare1);
  printf("\n升序后的數(shù)據(jù):\n");
  for (vector<Student>::iterator it = v.begin(); it != v.end(); it++)
  {
    printf("%s; %d\n", ((*it).name).c_str(), (*it).core);
  }
  //降序排序
  sort(v.begin(), v.end(), compare2);
  printf("\n降序后的數(shù)據(jù):\n");
  for (vector<Student>::iterator it = v.begin(); it != v.end(); it++)
  {
    printf("%s; %d\n", ((*it).name).c_str(), (*it).core);
  }
  getchar();
  return 1;
}

六:查找

  vector<int>::iterator it = find(v.begin(), v.end(), 5);
  if(it != v.end())
  {
    cout << "found";
  }
  else
  {
    cout << "not found";
  }

七:刪除

  for(vector<int>::iterator it=v.begin(); it != v.end(); it++)
  {
    if(*it == 8)
    {
      it = v.erase(it);//it會++一次
      it--;    //刪除完后需要--,否則最終循環(huán)越界
    }
  }

八:釋放內(nèi)存

存放整形vector釋放

 //存放整型
 vector<int> v;
 for (int i=0; i<100; i++)
 {
 v.push_back(i);
 }
  //釋放內(nèi)存
  {
    vector<int> vEmpty;
    v.swap(vEmpty);
  }

存放結(jié)構(gòu)體vector釋放

 //存儲結(jié)構(gòu)體
 vector<Student> vStu1;
 for (int i=0; i<10; i++)
 {
 Student stu;
 strcpy(stu.name, "woniu201");
 stu.age = 30 + i;
 vStu1.push_back(stu);
 }
 //釋放內(nèi)存  
    {
      vector<Student>
    }
 vector<Student> vEmpty;
     vStu1.swap(vEmpty);

存放結(jié)構(gòu)體指針vector釋放

 //存儲結(jié)構(gòu)體指針
 vector<Student*> vStu2;
 for (int i=0; i<10; i++)
 {
 Student* pStu = (Student*)malloc(sizeof(Student));
 strcpy(pStu->name, "wangpengfei");
 pStu->age = 30 + i;
 vStu2.push_back(pStu);
 }
 //釋放內(nèi)存
 for (vector<Student*>::iterator it = vStu2.begin(); it != vStu2.end(); it++)
 {
 if (NULL != *it)
 {
  delete *it;
  *it = NULL;
 }
 }

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

相關(guān)文章

  • C++ namespace命名空間解析

    C++ namespace命名空間解析

    考慮一種情況,當我們有兩個同名的人,Zara,在同一個班里。當我們需要對它們進行區(qū)分我們必須使用一些額外的信息和它們的名字,比如它們生活在不同的區(qū)域或者興趣愛好什么的,在C++程序中也會遇到同樣的情況,所以命名空間就此產(chǎn)生
    2021-11-11
  • 詳解C++編程中對二進制文件的讀寫操作

    詳解C++編程中對二進制文件的讀寫操作

    這篇文章主要介紹了C++編程中對二進制文件的讀寫操作,是C++入門學習中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-09-09
  • C語言三子棋游戲的簡單設(shè)計

    C語言三子棋游戲的簡單設(shè)計

    這篇文章主要為大家詳細介紹了C語言三子棋游戲的簡單設(shè)計,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • C++報錯`Null Pointer Dereference`的解決方法

    C++報錯`Null Pointer Dereference`的解決方法

    在軟件開發(fā)中,Null Pointer Dereference 是一種常見的錯誤,它發(fā)生在程序試圖訪問或操作一個空指針指向的內(nèi)存位置時,這種情況通常會導致程序崩潰,給 debug 工作帶來很大困擾,今天,我們將探討如何解決 Null Pointer Dereference 報錯,需要的朋友可以參考下
    2024-07-07
  • C++程序中添加.c.h的實現(xiàn)方法

    C++程序中添加.c.h的實現(xiàn)方法

    這篇文章主要介紹了C++程序中添加.c.h的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • 超詳細解析C++實現(xiàn)快速排序算法的方法

    超詳細解析C++實現(xiàn)快速排序算法的方法

    快速排序是比較快的排序方法。它的基本思想是通過一組排序?qū)⒁判虻臄?shù)據(jù)分割成獨立的兩部分,本文將用C++實現(xiàn)快速排序算法,需要的可以參考一下
    2022-09-09
  • C++實現(xiàn)獲取IP、子網(wǎng)掩碼、網(wǎng)關(guān)、DNS等本機網(wǎng)絡(luò)參數(shù)的方法

    C++實現(xiàn)獲取IP、子網(wǎng)掩碼、網(wǎng)關(guān)、DNS等本機網(wǎng)絡(luò)參數(shù)的方法

    這篇文章主要介紹了C++實現(xiàn)獲取IP、子網(wǎng)掩碼、網(wǎng)關(guān)、DNS等本機網(wǎng)絡(luò)參數(shù)的方法,需要的朋友可以參考下
    2014-07-07
  • 數(shù)組中求第K大數(shù)的實現(xiàn)方法

    數(shù)組中求第K大數(shù)的實現(xiàn)方法

    本篇文章是對數(shù)組中求第K大數(shù)的實現(xiàn)方法進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C/C++檢測文件是否存在的常見方法

    C/C++檢測文件是否存在的常見方法

    在C和C++中,檢測文件是否存在的方法通常涉及到平臺特定的API或者使用標準庫的功能(在C++17及以后版本中),本文給大家介紹了C/C++檢測文件是否存在的幾種常見方法,感興趣的小伙伴跟著小編一起來看看吧
    2024-06-06
  • opencv實現(xiàn)多張圖像拼接

    opencv實現(xiàn)多張圖像拼接

    這篇文章主要為大家詳細介紹了opencv實現(xiàn)多張圖像拼接功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01

最新評論