STL

一、vector动态数组

1 包含头函数 #include<vector>

2 函数的声明: vector<int> v;

       vector<int> v[maxn];

       vector<int> v(100,1); //100个1

3 操作常用:

  v.push_back(x); 在最后添加一个元素x

  v.pop_back(); 删去最后一个元素

  v.begin(); 返回第一个元素的指针

  v.end();返回最后一个元素的指针

  v.at(n);返回n位置的元素

  v.clear();清空数组

  v.size();返回数组长度

  v.front();返回第一个元素

  v.back();返回最后一个元素

  v.empty();如果数组为空返回true,否则返回false

  v.resize(n);重新定义数组大小为n

二、set 元素

1、包含头函数: #include<set>

2、函数声明: set<int> s;   (string等)

3、set是集合,不会包含重复的元素。因此可以用来查找统计不重复的元素

4、操作常用:

  s.insert(x);插入元素x

  s.erase(x);删除元素x(如果x存在)

  if (s.find(x)!=s.end())  判断元素是否属于集合(因为如果不属于返回值为s.end())

  s.size();返回集合长度

  s.empty();如果集合为空,则返回true

  s.clear();清空集合

  s.begin();指向第一个元素位置

  s.end();指向最后一个元素后面

  set<int>::iterator it; 定义一个指针

  s.count(i); i 在集合中,返回 1

三、map 映射

1、包含头函数: #include<map>

2、 函数声明: map<int,string> m1;

       map<string,int> m2;

3 map是将数据进行一对一的对应,使其更好描述。

4 操作常用:

  (1)读入数据:m1[1]="the_first_one";

  (2)数据大小:len=m.size();

  (3) 数据遍历:for(int i=1;i<=len;i++) cout<<m1[i];

  (4)数据查找:m.count() ;不能返回位置,只返回true、false;

         m.find(); 返回位置指针,不在中就返回m.end(); 

  (5)数据清空:m.clear();

 

四、queue 队列

1、包含头函数 #include<queue>

2、声明: queue<int> q;

3、queue在队列的使用中,较自定义的数组更方便,所以常使用在广搜中。

4、操作常用:

  q.empty();如果队列为空则返回true

  q.front();返回队列第一个值

  q.pop();删除队列最后一个

  q.push(x);添加x到队列最后

  q.size();返回队列长度

STL 自学的更多相关文章

  1. C++ STL自学总结,仅供参考

    本文内容,为博主在网上看到资料总结整合而来 一.stl格式简介 .stl文件是在计算机图形应用系统,来表示封闭的面或者体,用来表示三角形网格的一种文件格式.为STereo Lithography的缩写 ...

  2. 跟我学STL系列(1)——STL入门介绍

    一.引言 最近这段时间一直都在自学C++,所以这里总结下自己这段时间的学习过程,通过这种方式来巩固自己学到的内容和以备后面复习所用,另外,希望这系列文章可以帮助到其他自学C++的朋友们. 由于本人之前 ...

  3. PJ可能会考的模拟与枚举-自学教程

    PJ可能会考的模拟与枚举-自学教程 文/Pleiades_Antares 之前学校里看一个小可爱复习的时候偷偷听来着XD 简单记了一下重点吧,希望能对看官您有所帮助XD 以下⬇️是几个复习时讲过的题, ...

  4. stl学习记录(2)

    #include <iostream> #include <utility> #include <tuple> #include <complex> # ...

  5. Linux下新手怎样将VIM配置成C++编程环境(能够STL自己主动补全)

    ~ 弄拉老半天,最终弄的几乎相同啦,果然程序猿还是须要有点折腾精神啊. 首先你要安装vim,命令:sudo apt-get install vim vim它仅仅是一个编辑器,它不是IDE(比方code ...

  6. CS基础课不完全自学指南

    本文讲的是计算机学生怎么自学专业课,说长点就是该如何借助网络上已有的高质量学习资源(主要是公开课)来系统性的来点亮自己的CS技能树.这篇文章完全就是一篇自学性质的指南,需要对编程充满热情,起码觉得编程 ...

  7. QT5 QSS QML界面美化视频课程系列 QT原理 项目实战 C++1X STL

    QT5 QSS QML界面美化视频课程系列 QT原理 项目实战 C++1X STL 课程1   C语言程序设计高级实用速成课程 基础+进阶+自学 课程2   C语言程序设计Windows GDI图形绘 ...

  8. 从零自学Hadoop(22):HBase协处理器

    阅读目录 序 介绍 Observer操作 示例下载 系列索引 本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,Sour ...

  9. 前端自学路线之js篇

    上一篇我们讲了前端切图的学习路线,不知大家有没有收获.今天来聊聊前端工程师的核心技能之——JavaScript.js这门语言看似简单,但要做到入门.熟练以至于架构的程度,还是有一段路要走的,今天就来聊 ...

随机推荐

  1. 【Todo】Java新技术学习笔记-from某技术分析

    看到这篇文章:http://mt.sohu.com/20160806/n462923089.shtml <十余年技术大牛告诉你,这些Java新技术不可错过> 虽然讲的比较泛,但是里面提到的 ...

  2. POJ 2063 Investment 完全背包

    题目链接:http://poj.org/problem?id=2063 今天果然是卡题的一天.白天被hdu那道01背包的变形卡到现在还没想通就不说了,然后晚上又被这道有个不大也不小的坑的完全背包卡了好 ...

  3. vi编辑器简单应用(摘抄)

    摘抄于 vi编辑器的使用 (2) (3) 1 vi编辑器的基本使用 1.1 vi的启动 打开: $ vi example.c 只读打开 $ vi –R example.c 1.2 vi的工作模式 1. ...

  4. word双栏排版,最后一页由于分节符造成最后一页是空白页,删除分节符双栏就变成了单栏

    遇到这个问题时,我们把心思都花在了如何“删除”这个空白页. 但是最有效的办法不是“删除”,而是(以word2007为例): Word 2007中文版: 鼠标放在最后一页,点击页面布局①,选择页面布局右 ...

  5. phalcon: 资源文件管 理 引入css,js

    <?php class IndexController extends Phalcon\Mvc\Controller { public function index() { //添加本地css资 ...

  6. 20145218 《Java程序设计》第03次实验报告

    北京电子科技学院(BESTI)实验报告 课程:Java程序设计 班级:1452 指导教师:娄嘉鹏 实验日期:2016.04.22 实验名称:敏捷开发与XP实践 一.实验内容 XP基础 XP核心实践 相 ...

  7. CentOS安装vim

    VMware下CentOS安装成功后,默认自带vi,但vi功能没vim丰富.以下为CentOS中安装vim: 用yum产看源中的vim安装包: [xi@localhost ~]$ yum search ...

  8. ember

    为什么要用这种单页面应用.单页面应用就可以是一个web app ,而不是一个web site了,但是百度的大王是退mvc的,考虑到gc什么的? 所以说写组件component和mvc压根是两个完全从角 ...

  9. 《javascript高级程序设计》第三章 Language Basics

    3.1 语法syntax 3.1.1 区分大小写case-sensitivity 3.1.2 标识符identifiers 3.1.3 注释comments 3.1.4 严格模式strict mode ...

  10. 1029c语言文法2理解

    program → external_declaration | program external_declaration <程序>→ <外部声明>|<程序>< ...