浅谈STL(未完)
前言:
(1)学习资料——《算法笔记》第六章、《常用基础数据结构》文档

(2)测试平台——Codeup新家(《算法笔记》对应OJ)、洛谷、YCOJ

(3)学习时间——2020.6.2~


学习内容汇总:

一、Vector

1、简介:vector向量,也叫“变长数组”

2、运用:

(1)定义:vector<typename> name;
  
  注意:typename可以是任意类型,但如果typename也是一个STL容器,则在“>>”之间需要打空格;name也可以是数组
  
  (2)访问:①直接通过下标访问(0~size()-1)
  
  ②通过迭代器访问:vector<typename>::iterator it;
  
  注意:只有vector和string支持*(it+i)的访问方式
  
  (3)操作:①添加push_back()
  
  ②删除pop_back() 
  
  ③插入insert()
  
  ④清空clear()
  
  ⑤删除erase(it)或erase(first,last)
  
  ⑥长度size()
  
  (4)常见用途:①因为可以“变长”,所以对于储存数据很好用
  
  ②用邻接表存储图

3、题目:

(1)http://codeup.cn/contest.php?cid=100000596 (Codeup两道)

(2)打印锯齿矩阵(计蒜客)


 二、Set

1、简介:set集合,可将元素去重并升序排列

2、运用:

(1)定义:set<typename> name; 注意同上

(2)访问:只能通过迭代器:set<typename>::iterator it;

(3)操作:①插入insert()

②返回set中对应值为value的迭代器find(value)

③删除erase(it)或erase(value)或erase(first,last)

④长度size()

⑤清空clear()

(4)常见用途:主要用于处理元素去重并排序的问题

(5)补充:①不去重只升序:multiset  ②只去重不升序:unordered_set

3、题目:

(1)http://codeup.cn/contest.php?cid=100000597  (Codeup)

(2)http://120.77.248.79/problem/2021102  计算集合的并(YCOJ)


 三、String

1、简介:string用于处理字符串

2、运用:

(1)定义:string s;

(2)读入读出:cin和cout

(3)迭代器:string::iterator it;

(4)可将两个string直接拼凑起来或进行比较大小(规则是字典序)

(5)操作:①长度length()或size()

②在pos位插入strinsert(pos,str)或将【it2,it3)插入到it的的位置insert(it,it2,it3)

③删除同vector或从pos位开始删除length个字符erase(pos,length)

④清空clear()

⑤返回从pos位开始长度为len的子串substr(pos,len)

⑥当str是s的子串时返回str第一次出现的位置find(str)或从s的pos位开始匹配str,返回值同上find(str,pos)

⑦把s从pos位开始、长度为len的子串替换为strreplace(pos,len,str)或把s的迭代器【it2,it3)范围的子串替换为strrelace(it2,it3,str)

3、题目:

(1)http://codeup.cn/contest.php?cid=100000598  字符串处理(Codeup)


四、Map

1、简介:map映射,将任一类型映射到任一类型且会按键自动升序

2、运用:

(1)定义:map<typename1,typename2> name;typename1为键的类型,typename2为映射值的类型

(2)访问:①通过下标访问,因为键的值唯一

②迭代器map<typename1,typename2>::iterator it;,然后用it->first来访问键、用it->second来访问值

(3)操作:①查找键为key的迭代器find(key)

②删除erase(it)或erase(key)删除键key或删除区间erase(first,last)

③长度size()

④清空clear()

3、常见用途:①字符与整数之间的关系

②map当作bool用

③字符串与字符串的映射

4、补充:一个键对应多个值,multimap

5、题目:

(1)http://codeup.cn/contest.php?cid=100000599  (Codeup)

(2)蒜头军破案——二维map  (计蒜客)

(3)蒜头军的藏书——字符串与整数  (计蒜客)

(4)小信学英语——字符串与整数  (YCOJ)

(5)小信的面试  (YCOJ)

(6)水果店——二维map  (YCOJ)


STL标准函数库学习小总结的更多相关文章

  1. C++STL标准库学习笔记(三)multiset

    C++STL标准库学习笔记(三)multiset STL中的平衡二叉树数据结构 前言: 在这个笔记中,我把大多数代码都加了注释,我的一些想法和注解用蓝色字体标记了出来,重点和需要关注的地方用红色字体标 ...

  2. C++STL标准库学习笔记(一)sort

    前言: 近来在学习STL标准库,做一份笔记并整理好,方便自己梳理知识.以后查找,也方便他人学习,两全其美,快哉快哉! 这里我会以中国大学慕课上北京大学郭炜老师的<程序设计与算法(一)C语言程序设 ...

  3. C++STL标准库学习笔记(五)set

    前言: 在这个笔记中,我把大多数代码都加了注释,我的一些想法和注解用蓝色字体标记了出来,重点和需要关注的地方用红色字体标记了出来,这一篇后面主要都是我的记录了,为了防止大片蓝色字体出现,后面就不改蓝色 ...

  4. C++STL标准库学习笔记(二)二分查找

    二.STL中的二分查找算法 1.binary_search 2.lower_bound 3.upper_bound 记得#include<algorithm>! 前言: 在这个笔记中,我把 ...

  5. C++STL标准库学习笔记(四)multiset续

    自定义排序规则的multiset用法 前言: 在这个笔记中,我把大多数代码都加了注释,我的一些想法和注解用蓝色字体标记了出来,重点和需要关注的地方用红色字体标记了出来,只不过这一次的笔记主要是我的补充 ...

  6. 分治算法(二分查找)、STL函数库的应用第五弹——二分函数

    分治算法:二分查找!昨天刚说不写算法了,但是突然想起来没写过分治算法的博客,所以强迫症的我…… STL函数库第五弹——二分函数lower_bound().upper_bound().binary_se ...

  7. STL函数库的应用第四弹——全排列(+浅谈骗分策略)

    因为基础算法快学完了,图论又太难(我太蒻了),想慢慢学. 所以暂时不写关于算法的博客了,但又因为更新博客的需要,会多写写关于STL的博客. (毕竟STL函数库还是很香的(手动滑稽)) 请出今天主角:S ...

  8. dlib库学习之一

    dlib库学习之一 1.介绍 跨平台 C++ 通用库 Dlib 发布 ,带来了一些新特性,包括概率 CKY 解析器,使用批量同步并行计算模型来创建应用的工具,新增两个聚合算法:中国低语 (Chines ...

  9. Standard C 语言标准函数库速查(彩色的函数列表,十分清楚)

    Standard C 语言标准函数库速查 (Cheat Sheet) wcstombs 函数说明 #include <stdlib.h> size_t mbstowcs(wchar_t * ...

随机推荐

  1. Java实现 LeetCode 654 最大二叉树(递归)

    654. 最大二叉树 给定一个不含重复元素的整数数组.一个以此数组构建的最大二叉树定义如下: 二叉树的根是数组中的最大元素. 左子树是通过数组中最大值左边部分构造出的最大二叉树. 右子树是通过数组中最 ...

  2. Java实现 蓝桥杯VIP基础练习 矩形面积交

    描述 平面上有两个矩形,它们的边平行于直角坐标系的X轴或Y轴.对于每个矩形,我们给出它的一对相对顶点的坐标,请你编程算出两个矩形的交的面积. 输入 输入仅包含两行,每行描述一个矩形. 在每行中,给出矩 ...

  3. Java实现 LeetCode 322 零钱兑换

    322. 零钱兑换 给定不同面额的硬币 coins 和一个总金额 amount.编写一个函数来计算可以凑成总金额所需的最少的硬币个数.如果没有任何一种硬币组合能组成总金额,返回 -1. 示例 1: 输 ...

  4. Java实现 LeetCode 217 存在重复元素

    217. 存在重复元素 给定一个整数数组,判断是否存在重复元素. 如果任何值在数组中出现至少两次,函数返回 true.如果数组中每个元素都不相同,则返回 false. 示例 1: 输入: [1,2,3 ...

  5. Java实现 蓝桥杯VIP 算法提高 身份证排序

    算法提高 身份证排序 时间限制:1.0s 内存限制:256.0MB 问题描述 安全局搜索到了一批(n个)身份证号码,希望按出生日期对它们进行从大到小排序,如果有相同日期,则按身份证号码大小进行排序.身 ...

  6. java实现第六届蓝桥杯熊怪吃核桃

    熊怪吃核桃 题目描述 森林里有一只熊怪,很爱吃核桃.不过它有个习惯,每次都把找到的核桃分成相等的两份,吃掉一份,留一份.如果不能等分,熊怪就会扔掉一个核桃再分.第二天再继续这个过程,直到最后剩一个核桃 ...

  7. zabbix 交换机端口显示端口描述

    ZABBIX 监控系统流量图显示端口描述   进入web 选择配置--主机 选择触发器原型 编辑触发器 随便点开一个触发器 选择触发器原型   逐个点开修改 {#IFDESCR}: ({#IFALIA ...

  8. Java 中队列同步器 AQS(AbstractQueuedSynchronizer)实现原理

    前言 在 Java 中通过锁来控制多个线程对共享资源的访问,使用 Java 编程语言开发的朋友都知道,可以通过 synchronized 关键字来实现锁的功能,它可以隐式的获取锁,也就是说我们使用该关 ...

  9. SQL2008R2安装碰到问题的解决方法(iso文件用对应的工具)

    SQL2008R2安装碰到问题的解决方法     安装谁不会啊,这么简单,是啊,可是匹配包时就不是那么顺利啊.就像以前的Ruby还专挑匹配版本的包一样,不像现在的Py自动为我们找,这是Mar 7贴在Q ...

  10. Express4.x之API:express

    express()表达式 express的方法 express功能分析 一.express()表达式 创建Express应用程序.express()函数是express模块导出的顶级函数.(相当于HT ...