I.vector

1.头文件:#include<vector>                        //容器vector是一个能实现随机存取、插入删除的动态数组,还可以当栈使。  

2.创建: vector<int> v1;                             // < >里可以是struct或者vector嵌套:vector< vector<int> > ivec;

vector是一个类模板,创建一个vector的过程称为实例化。

3.初始化:

  • vector<T> v2(v1);   //  效果同拷贝初始化 vector<T> v2=v1;
  • vector<T> v2(n,val);
  • vector<T> v2{a,b,c,d};  // vector<T> v2={a,b,c,d};
  • 数组指针
  • int iarray[]={,,,,,,,,,,};
    vector<int> v1(iarray,iarray+sizeof(iarray)/sizeof(int));

4.尾部插入数字:v1.push_back(a);     //  pop_back();

5.下标实现随机存取: v1[0]=a;

6.常用函数: empty()  size()  clear()  <=

7.使用迭代器访问元素.

vector<int>::iterator it;
for(it=v1.begin();it!=v1.end();it++)
cout<<*it<<endl;

8.插入和删除 insert,erase   配合迭代器,如删除所有值为8的元素

v1.insert(v1.begin()+i,a);  //在第i+1个元素前面插入a

v1.erase(v1.begin()+2);  //删除第3个元素

9.#include<algorithm>

(1) 元素翻转:

reverse(vec.begin(),vec.end());   //将元素翻转(在vector中,如果一个函数中需要两个迭代器,一般后一个都不包含.)

(2)排序:

bool Comp(const int &a,const int &b){
return a>b;
} sort(vec.begin(),vec.end());  //升序排列
sort(vec.begin(),vec.end(),Comp)  //降序排序

II.string

1.头文件:#include<string>

2.创建与初始化:类似vector

3.写入读取:

  • cout<<s;  cin>>s;  //以空白(空格、换行、制表符)判断开始结尾,并忽略之  
  • getline(cin,s);    //读一行,以换行符判断结束,并抛弃换行符

4.empty, size, +, =, <, [],  append/push_back

5.关于字符变量的函数:isalnum,isalpha,isdigit / tolower,toupper       <cctype>

6.高级:  

  • 子串:  string substr(int pos = 0,int n = npos) const;//返回pos开始的n个字符组成的字符串
  • 交换:  void swap(string &s2);    //交换当前字符串与s2的值
  • 查找函数:
    • int find(char c, int pos = 0) const;//从pos开始查找字符c在当前字符串的位置
    • int find(const char *s, int pos, int n) const;//从pos开始查找字符串s中前n个字符在当前串中的位置
    • int find(const string &s, int pos = 0) const;//从pos开始查找字符串s在当前串中的位置

 

III.map

1.头文件:#include<map>                        //容器map是一个能实现key到value单射的关联容器,对应数据结构为hash表,其内元素按键值升序排列,键值唯一。

2.构造:map <string,int> m1;

3.添加元素: m1["hello"]=5;         //下标既能访问也能赋值也能添加,insert()添加效率高   insert(map<int, CString> :: value_type(2, "Two"))

4.常用函数: empty()  size()  clear()    迭代器  begin() , end(), erase()         // m1.erase("hi"); m1.erase(it); m1.erase(it,it+5);

5.按键值查找一个元素       //根据key值快速查找记录,查找的复杂度基本是Log(N)

  • 返回其迭代器:    find()       // if( m1.find("hi")==m1.end() )  如果该key不存在
  • 返回指定元素出现的次数:  count()

IV. struct

//Definition for singly-linked list.
struct ListNode {
int val;
ListNode *next;
ListNode(int x) : val(x), next(NULL) {}
};

  

typedef struct rect
{
int id;
int length;   bool operator< (const rect &a) const
{
if(id!=a.id)
return id<a.id;
else
{
if(length!=a.length)
return length<a.length;
}
}
}Rect;

  

STL review:vector & string & map & struct的更多相关文章

  1. C/C++解题常用STL大礼包 含vector,map,set,queue(含优先队列) ,stack的常用用法

    每次忘记都去查,真难啊 /* C/C++解题常用STL大礼包 含vector,map,set,queue(含优先队列) ,stack的常用用法 */ /* vector常用用法 */ //头文件 #i ...

  2. Effective STL 学习笔记 Item 16:vector, string & C API

    有时需要支持 C 的接口,但这并不复杂. 对于 vector 来讲, \(v[0]\) 的地址 \(\&v[0]\) 即可作为数组指针传递给 C API: 1: // Legacy C API ...

  3. 10、Cocos2dx 3.0游戏开发找小三之容器篇:Vector、Map、Value

    重开发人员的劳动成果.转载的时候请务必注明出处:http://blog.csdn.net/haomengzhu/article/details/27705613 容器 3.0版本号之前Cocos2d- ...

  4. C++ 标准模板库(STL):vector

    目录 1. vector 1.1 vector的定义 1.2 vector容器内元素的访问 1.3 vector 常用函数实例解析 1.4 vector的常见用途 1. vector 变长数组,长度根 ...

  5. CPP-STL:vector容器

    1.     vector容器简介: vector向量容器是一种随机访问的数组类型,它提供了对数组元素的快速访问.随机访问,以及在序列尾部快速.随机地插入和删除操作.它类似于数据结构中的队列.数组和堆 ...

  6. STL源代码学习--vector用法汇总

    一.容器vector 使用vector你必须包含头文件<vector>: #include<vector> 型别vector是一个定义于namespace std内的templ ...

  7. 顺序容器:vector,deque,list

    1.顺序容器:vector,deque,list 容器类共享公共接口,只要学会其中一种类型就能运用另一种类型.每种容器提供一组不同的时间和功能这种方案,通常不需要修改代码,秩序改变类型声明,每一种容器 ...

  8. STL学习:STL库vector、string、set、map用法

    本文仅介绍了如何使用它们常用的方法. vector 1.可随机访问,可在尾部插入元素:2.内存自动管理:3.头文件#include <vector> 1.创建vector对象 一维: (1 ...

  9. Effective STL 学习笔记: 多用 vector & string

    Effective STL 学习笔记: 多用 vector & string 如果可能的话, 尽量避免自己去写动态分配的数组,转而使用 vector 和 string . 原书作者唯一想到的一 ...

随机推荐

  1. Laravel 5 Form 和 HTML 的使用

    最近在用 laravel 5 做例子,在做到表单的时候,习惯性的使用 Form::open() 结果发现提示错误,没有这个类, 好吧,找了找,发现 在laravel 5 中,把 from 和 html ...

  2. 改变input的value值,同时在HTML中将value进行改变

    在使用lodop进行打印的时候,需求中有这样一个功能:某个字段可以在页面的input框中进行修改. 但是在进行打印时调用的是静态的HTML代码,这就导致在页面的input框中改变字段之后,但是HTML ...

  3. 【shell】shell编程(四)-循环语句

    上篇我们学习了shell中条件选择语句的用法.接下来本篇就来学习循环语句.在shell中,循环是通过for, while, until命令来实现的.下面就分别来看看吧. for for循环有两种形式: ...

  4. POJ Blue Jeans [枚举+KMP]

    传送门 F - Blue Jeans Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u ...

  5. Rmq Problem

    大视野——3339: Rmq Problem Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 1192  Solved: 620[Submit][Sta ...

  6. 如何细粒度地控制你的MyBatis二级缓存(mybatis-enhanced-cache插件实现)

    前几天网友chanfish 给我抛出了一个问题,笼统地讲就是如何能细粒度地控制MyBatis的二级缓存问题,酝酿了几天,觉得可以写个插件来实现这个这一功能.本文就是从问题入手,一步步分析现存的MyBa ...

  7. 三期_day05_Dao层的准备工作_II

    工作文件夹: 实体类:UserInfo.java package com.yc.crm.entity; import java.util.Date; public class UserInfo { p ...

  8. Android studio 导入githubproject

    Blog From:http://blog.csdn.net/onlysnail/article/details/45115093 从github下载两个开源项目: PagerSlidingTabSt ...

  9. CF 558B(Amr and The Large Array-计数)

    B. Amr and The Large Array time limit per test 1 second memory limit per test 256 megabytes input st ...

  10. 使用UltraISO刻录自己的音乐CD步骤

    1.文件->新建->音乐光盘映像. 2.在左下方,“本地目录”中,找到音乐所在目录,右下方会出现mp3等音乐文件. 3.在右下方,点击音乐文件,右键选“添加”.音乐文件会出现在右上方窗口里 ...