• c++ vector 常用函数


    Just like arrays, vectors use contiguous storage locations for their elements, which means that their elements can also be accessed using offsets on regular pointers to its elements, and just as efficiently as in arrays. But unlike arrays, their size can change dynamically, with their storage being handled automatically by the container.

    vector也是一个数组但是它的占用的内存大小是动态变化的。当vector占用的内存满了之后,就要重新分配内存,并且赋值原来的所有元素,为了避免频繁的重新分配内存,迁移数据。vector实际分配的内存比你需要的内存多。比如你有10个int的数据在vector中,vector实际占用的内存是20个int的内存, 当你数据占用超过实际占用内存的比例的时候,vector就会自动重新分配内存,迁移数据. vector实际占用的内存可以用capacity()来查看

     1 #include<iostream>
     2 #include<vector>
     3 using namespace std;
     4 int main(){
     5     vector<int> ans;
     6     for(int i=0; i<10; i++) ans.push_back(i);
     7     ans.erase(ans.begin()+2);
     8     cout<<"擦除第三个数字:";
     9     for(int j=0; j<ans.size(); j++) cout<<ans[j]<<" ";
    10     ans.erase(ans.begin(), ans.begin()+2);
    11     cout<<endl<<"擦除前2个数字:";
    12     for(int k=0; k<ans.size(); k++) cout<<ans[k]<<" ";
    13     //尽量不要频繁使用这个函数,会引起大量数据移动,降低程序效率
    14     ans.insert(ans.begin()+1, 100);
    15     cout<<endl<<"在第一位后面插入100:";
    16     for(int m=0; m<ans.size(); m++) cout<<ans[m]<<" ";
    17     //vector在声明的时候,可以申明大小和默认值
    18     vector<int> temp(5, -1);
    19     cout<<endl<<"temp的大小为5,默认值是-1:";
    20     for(int l=0; l<temp.size(); l++) cout<<temp[l]<<" ";
    21     //resize(int n)改变vector实际储存的数据个数, 如果n比实际个数多,则多出的位添加0,否则截取掉多余数据
    22     temp.resize(8);
    23     cout<<endl<<"把temp的大小改变位8:";
    24     for(int h=0; h<temp.size(); h++) cout<<temp[h]<<" ";
    25     //在改变vector大小的同时还能指定多余内存的值;这种方式只适用于分配的空间比原来的多的情况
    26     temp.resize(10, 1111);
    27     cout<<endl<<"temp的大小改为10,并且指定多出来空间的值位11111:";
    28     for(int g=0; g<temp.size(); g++)cout<<temp[g]<<" ";
    29     cout<<endl<<"获取temp的第一个元素:"<<temp.front()<<endl<<"获取temp的最后一个元素:"<<temp.back();
    30     //常用empty()和size函数来判断vector是否为空,当vector为空的时候, empty()返回true, size()的值为0
    31 return 0;}

    此外可以配合#include<algorithm>库中的unique函数来删除vector中的重复元素

    vector<int> ans;
    ans.erase(unique(ans.begin(), ans.end()), ans.end());
    有疑惑或者更好的解决方法的朋友,可以联系我,大家一起探讨。qq:1546431565
  • 相关阅读:
    windows下一些启动服务的命令
    使用命令行启动服务
    无法向会话状态服务器发出会话状态请求转
    SQLServer跨服务器连接的多种方法
    Response.Buffer = True
    UpdatePanel和Jquery冲突
    <iframe>标签自适应高度和宽度
    java判断获取到的中文字符串是否乱码
    MMC不能打开文件C:\WINDOWS\SYSTEM32\inetsrv\iis.msc,如何解决?
    在.NET中用excel导出(概要)
  • 原文地址:https://www.cnblogs.com/mr-stn/p/9031676.html
Copyright © 2020-2023  润新知