zoukankan      html  css  js  c++  java
  • 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;

        }
    4.总结

    #include <stdio.h>
    #include <algorithm>
    #include <iostream>
    #include <vector>
    using namespace std;
    
    bool comp( const int &a,const int &b ){
        return a>b;//降序,a>b时返回true,为true时调换顺序
    }
    
    void main(){
        vector<int> vec;
        vec.push_back(5);
        cout<<"1st element:"<<vec[0]<<endl;
        vec.push_back(2);
        vec.push_back(5);
        vec.push_back(8);
        vec.push_back(1);
        vec.push_back(7);
    
        vector<int>::iterator it;
        cout<<"after push:"<<endl;
        for( it=vec.begin();it!=vec.end();it++ ){
            cout<<"element:"<<*it<<endl;
        }
    
        sort(vec.begin(),vec.end());
        //sort(vec.begin(),vec.end(),comp);
        cout<<"after sort:"<<endl;
        for( it=vec.begin();it!=vec.end();it++ ){
            cout<<"element:"<<*it<<endl;
        }
        reverse(vec.begin(),vec.end());
        cout<<"after reverse"<<endl;
        for( it=vec.begin();it!=vec.end();it++ ){
            cout<<"element:"<<*it<<endl;
        }
    
        vec.insert(vec.begin()+2,22);//插入在这个位置,全体元素向后移动
        cout<<"after insert:"<<endl;
        cout<<"3th element:"<<vec[2]<<endl;
        cout<<"4th element:"<<vec[3]<<endl;
    
        vec.erase(vec.begin()+2);
        cout<<"after erase:"<<endl;
        cout<<"vector size:"<<vec.size()<<endl;
    
        vec.clear();
        cout<<"after clear:"<<endl;
        cout<<"vector size:"<<vec.size()<<endl;
    
        system("pause");
    }
  • 相关阅读:
    基于麦克风阵列的声源定位算法之GCC-PHAT
    Parametric and Non-parametric Algorithms
    MATLAB中运算符优先级
    [HAOI2018]染色
    [SHOI2016]黑暗前的幻想乡
    [SCOI2012]滑雪
    [PA2014]Kuglarz
    Stroll
    [SDOI2010]大陆争霸
    解决IDEA Gradle构建报错"Cause: zip END header not found"
  • 原文地址:https://www.cnblogs.com/lucio_yz/p/5212274.html
Copyright © 2011-2022 走看看