---恢复内容开始---Vector 是一个类模板。不是一种数据类型。 Vector<int>是一种数据类型

类的作用,是一种顺序容器,支持随机访问,可动态分配空间(扩充:销毁旧内存,更新迭代器),线性的数据结构

《《《《    扩充:》》》》

vector容器类型

vector容器是一个模板类,可以存放任何类型的对象(但必须是同一类对象)。vector对象可以在运行时高效地添加元素,并且vector中元素是连续存储的。

1.对象的操作:

1.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           当前使用数据的大小(返回v中元素的个数,v.size())

11.resize         改变当前使用数据的大小,如果它比当前使用的大,者填充默认值

12.reserve      改变当前vecotr所分配空间的大小

13.erase         删除指针指向的数据项

14.clear          清空当前的vector

15.rbegin        将vector反转后的开始指针返回(其实就是原来的end-1)

16.rend          将vector反转构的结束指针返回(其实就是原来的begin-1)

17.empty        判断vector是否为空 (v.empty())

18.swap         与另一个vector交换数据

2.使用:

a:数组习惯使用    (已知大小,索引元素)

oo: vector<int>v(10);类似定义数组,可用v[i]来访问

oo:vector<int>v(10,-1);定义了v,包含10个int型初始值为-1

oo: vector<int>v(a,a+6);int a{1,2,3,4,5,6,7};将a中的6个元素拷贝到v中

  1. vector<string>s;//vector可被另一个vector初始化,也可赋值给另一个vector
  2. void init_and_assigh()
  3. {
  4. vector<string>names(s);//另一个vector初始化
  5. s=names;//拷贝
  6. }

b:STL习惯用法(定义空vector,插入元素,使用迭代器)

//两种方法数据的存入和输出

 #include<cstdio>
#include<vector>
#include<iostream>
using namespace std;
int main()
{
int i=;
vector<int>v;
for(i=;i<;i++)
{
v.push_back(i);
}
/****************
for(i=0;i<v.size();i++)
{
cout<<v[i]<<" ";
}
cout<<endl;
*******************/
vector<int>::iterator iter;
for(iter=v.begin();iter!=v.end();iter++)
{
cout<<*iter<<endl;
}
return ;
}//两种方法数据的存入输出

//对二维的定义

 #include<cstdio>
#include<vector>
#include<iostream>
using namespace std;
int main()
{
int i=;
vector<int>v;
for(i=;i<;i++)
{
v.push_back(i);
}
/* for(i=0;i<v.size();i++)
{
cout<<v[i]<<" ";
}
cout<<endl;*/
vector<int>::iterator iter;
for(iter=v.begin();iter!=v.end();iter++)
{
cout<<*iter<<endl;
}
return ;
}
 #include<stdio.h>
#include<vector>
#include<iostream>
using namespace std;
int main()
{
int i=,j=;
vector<vector<int> >Array;
vector<int>line;
for(j=;j<;j++)
{
Array.push_back(line);//初始化,存入元素
for(i=;i<;i++)
{
Array[j].push_back(i);
}
}
for(j=;j<;j++)
{
for(i=;i<Array[j].size();i++)
{
cout<<Array[j][i]<<" ";
}
cout<<endl;
}
return ;
}

初学鄙陋,只看到了皮毛。

---恢复内容结束---

初入水:vector的更多相关文章

  1. C++ 初读vector

    vector 向量(Vector)是一个封装了动态大小数组的顺序容器(Sequence Container).跟任意其它类型容器一样,它能够存放各种类型的对象. Character 高效 C++标准要 ...

  2. 数据结构《21》----2014 WAP 初试题----Immutable queue

    2014 WAP初试题----实现一个不可变的队列: 看似很简单..实则,不同的版本效率的差距可能是巨大的..甚至难以想象.. 之前用STL库的queue进行了对比,差别非常大.. 用上一篇文章的im ...

  3. 标准库类型vector

    标准库类型vector表示对象的集合,其中所有对象的类型都相同.集合中的每个对象都有一个与之对应的索引,索引用于访问对象.因为vector“容纳着”其他对象,所以它被称为容器. 要想使用vector, ...

  4. 平衡树初阶——AVL平衡二叉查找树+三大平衡树(Treap + Splay + SBT)模板【超详解】

    平衡树初阶——AVL平衡二叉查找树 一.什么是二叉树 1. 什么是树. 计算机科学里面的树本质是一个树状图.树首先是一个有向无环图,由根节点指向子结点.但是不严格的说,我们也研究无向树.所谓无向树就是 ...

  5. C++模板之Vector与STL初探

    STL源码初步接触 STL = Standard Template Library,直译过来是:标准模板库,是惠普实验室开发的一系列软件的统称.从根本上说,STL是一些"容器"的集 ...

  6. SuperMap iClient for JavaScript初入

    SuperMap iClient for JavaScript初入 介绍SuperMap for Js的简单使用. 推荐先看下这篇文档:SuperMap iClient for JavaScript ...

  7. C++标准模板库(STL)之Vector

    在C中,有很多东西需要自己实现.C++提供了标准模板库(Standard Template Libray,STL),其中封装了很多容器,不需要费力去实现它们的细节而直接调用函数来实现功能. 具体容器链 ...

  8. C++学习3--编程基础(vector、string、三种传参)

    知识点学习 Vector容器 vector是C++标准程序库中的一个类,其定义于头文件中,与其他STL组件一样,ventor属于STD名称空间: ventor是C++标准程序库里最基本的容器,设计之初 ...

  9. vector中删除的注意事项

    erase的函数原型有两种形式: iterator erase(iterator position); iterator erase(iterator first, iterator last); 例 ...

随机推荐

  1. 使用视 meta 标签来控制手机浏览器布局

    移动浏览器的Fennec一样呈现在一个虚拟的"窗口"页面(视),通常比屏幕宽.所以他们不需要去挤每个页面布局到一个小窗口(这会破坏许多非移动优化的网站) .用户可以平移和缩放才能看 ...

  2. SqlServer中使用正则表达式

    一.查看配置,如果‘show advanced options’,‘Ole Automation Procedures’,‘Ad Hoc Distributed Queries’的config_val ...

  3. C#面向对象设计模式纵横谈——2.Singleton 单件(创建型模式)

    一:模式分类 从目的来看: 创建型(Creational)模式:负责对象创建. 结构型(Structural)模式:处理类与对象间的组合. 行为型(Behavioral)模式:类与对象交互中的职责分配 ...

  4. 纪念BLives 1.0版本发布

    历时两个多月的时间,BLives程序1.0发布,在开发程序期间自己经历了很多,考试,恋爱,学业,自己很纠结 很伤心,有时候很无助,为了让自己有事干,我在考试备考期间去设计程序- -#,虽然程序设计的一 ...

  5. spring与hessian整合例

    spring与hessian的简单应用实现例: 开发环境:window7 64,jdk8,tomcat8,spring4.2.5,hessian4.0 开发语言:java hessianServer端 ...

  6. myql Connect

    mysql折腾笔记 2014-01-05 10:58 经常吹嘘自己玩过各种数据库. redis, mysql, sqlite, mongodb..常用数据库都不在话下,不料今天却在远程连接mysql上 ...

  7. mac机快捷键操作

    1. 屏幕最大和缩小:command+ctrl +f 2.切换应用:comand+tab, 3.大小写转换:comand + 空格 4.切换到下/上一个标签页:同时按 ⌘-Option 和向右/左箭头 ...

  8. thinkphp 3.2 linux二级目录安装

    详解:http://document.thinkphp.cn/manual_3_2.html#url_rewrite 注意:linux系统对大小写敏感 服务器系统:linux (阿里云服务器) thi ...

  9. G:首页调用“图片视频”的分类和文章(难点)

      1:后台获取:自定义分类的ID (默认分类也可获取)  2:动态获取"自定义分类的ID($cat)"  $cat_title = single_cat_title(' ', f ...

  10. IO例子

    1.用字节读取一个文件,替换换行符,并打印 String fileName = "src/learnIO/Stream.java"; FileInputStream in = ne ...