- 1、本文档共13页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
vector详解
?vector(向量): C++中的一种数据结构,确切的说是一个类.它相当于一个动态的数组,当程序员无法知道自己需要的数组的规模多大时,用其来解决问题可以达到最大节约空间的目的.?????用法:??????????1.文件包含:????????????????首先在程序开头处加上#includevector以包含所需要的类文件vector??????????还有一定要加上using namespace std;???????????2.变量声明:???????????????2.1 例:声明一个int向量以替代一维的数组:vector int a;(等于声明了一个int数组a[],大小没有指定,可以动态的向里面添加删除)。???????????????2.2 例:用vector代替二维数组.其实只要声明一个一维数组向量即可,而一个数组的名字其实代表的是它的首地址,所以只要声明一个地址的向量即可,即:vector int *?a.同理想用向量代替三维数组也是一样,vector int**a;再往上面依此类推.???????????3.具体的用法以及函数调用:??????????3.1 如何得到向量中的元素?其用法和数组一样:??????????例如:??????????vector int *?a??????????int b = 5;??????????a.push_back(b);//该函数下面有详解??????????couta[0];???????//输出结果为51.push_back?? 在数组的最后添加一个数据2.pop_back??? 去掉数组的最后一个数据?3.at??????????????? 得到编号位置的数据4.begin?????????? 得到数组头的指针5.end???????????? 得到数组的最后一个单元+1的指针6.front??????? 得到数组头的引用7.back??????????? 得到数组的最后一个单元的引用8.max_size???? 得到vector最大可以是多大9.capacity?????? 当前vector分配的大小10.size?????????? 当前使用数据的大小11.resize???????? 改变当前使用数据的大小,如果它比当前使用的大,者填充默认值12.reserve????? 改变当前vecotr所分配空间的大小13.erase???????? 删除指针指向的数据项14.clear????????? 清空当前的vector15.rbegin??????? 将vector反转后的开始指针返回(其实就是原来的end-1)16.rend????????? 将vector反转构的结束指针返回(其实就是原来的begin-1)17.empty??????? 判断vector是否为空18.swap???????? 与另一个vector交换数据??????????3.2 ?详细的函数实现功能:其中vectorint c.???????????????????????????? c.clear()?????????移除容器中所有数据。???????????????????????????? c.empty()?????????判断容器是否为空。???????????????????????????? c.erase(pos)????????删除pos位置的数据???????????????????????????? c.erase(beg,end)?删除[beg,end)区间的数据???????????????????????????? c.front()?????????传回第一个数据。???????????????????????????? c.insert(pos,elem)??在pos位置插入一个elem拷贝???????????????????????????? c.pop_back()?????删除最后一个数据。???????????????????????????? c.push_back(elem)?在尾部加入一个数据。???????????????????????????? c.resize(num)?????重新设置该容器的大小???????????????????????????? c.size()?????????回容器中实际数据的个数。???????????????????????????? c.begin()???????????返回指向容器第一个元素的迭代器???????????????????????????? c.end()?????????????返回指向容器最后一个元素的迭代器???????????????4.内存管理与效率?????
文档评论(0)