STL vector常用API
1、容器:序列容器(时间决定)、关联式容器(容器中的数据有一定规则)
2、迭代器:通过迭代器寻找、遍历容器中的数据
vetor的使用:数据遍历与输出
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<vector> //向量 动态数组
#include<algorithm> //算法头文件
#include<string>
using namespace std; void myPrint(int val){
cout << val << " ";
} //1. STL中的容器算法迭代器
void test01(){ //容器
vector<int> v;
v.push_back(10);
v.push_back(20);
v.push_back(30);
v.push_back(40);
v.push_back(50); //获得开始迭代器
vector<int>::iterator begin = v.begin();
//获得结束位置迭代器
vector<int>::iterator end = v.end(); //遍历算法
for_each(begin, end, myPrint);
cout << endl;
} //2. 容器可以存放对象
class Person{
friend ostream& operator<<(ostream& out, Person &person);
public:
Person(string name,int age){
this->mName = name;
this->mAge = age;
}
public:
string mName;
int mAge;
}; ostream& operator<<(ostream& out, Person &person){
out << "Name:" << person.mName << " Age:" << person.mAge << endl;
return out;
}
void test02(){ vector<Person> v;
//在向容器中插入元素的时候,一定要保证元素能够被拷贝。
v.push_back(Person("aaa", 10));
v.push_back(Person("bbb", 20));
v.push_back(Person("ccc", 30));
v.push_back(Person("ddd", 40));
v.push_back(Person("eee", 50)); vector<Person>::iterator begin = v.begin();
vector<Person>::iterator end = v.end(); while (begin != end){
cout << (*begin);
++begin;
}
} //3. 存放对象指针
void test03(){ vector<Person *> v; //创建数据
Person *p1 = new Person("aaa", 10);
Person *p2 = new Person("bbb", 20);
Person *p3 = new Person("ccc", 30);
Person *p4 = new Person("ddd", 40);
Person *p5 = new Person("eee", 50); v.push_back(p1);
v.push_back(p2);
v.push_back(p3);
v.push_back(p4);
v.push_back(p5); vector<Person *>::iterator begin = v.begin();
vector<Person *>::iterator end = v.end(); while (begin != end){
cout << (*begin)->mName << " " << (*begin)->mAge << endl;
++begin;
} delete p5;
delete p4;
delete p3;
delete p2;
delete p1; } //4. 容器可以嵌套容器
void test04(){ vector<vector<int>> vs; vector<int> v1;
vector<int> v2;
vector<int> v3;
vector<int> v4;
vector<int> v5; for (int i = 0; i < 5;i ++){
v1.push_back(i + 10);
v2.push_back(i + 20);
v3.push_back(i + 30);
v4.push_back(i + 40);
v5.push_back(i + 50);
} vs.push_back(v1);
vs.push_back(v2);
vs.push_back(v3);
vs.push_back(v4);
vs.push_back(v5); vector<vector<int>>::iterator begin = vs.begin();
vector<vector<int>>::iterator end = vs.end(); while (begin != end){ vector<int>::iterator sbegin = (*begin).begin();
vector<int>::iterator send = (*begin).end(); while (sbegin != send){
cout << *sbegin << " ";
++sbegin;
}
cout << endl; ++begin;
} cout << "-------------------" << endl; for (vector<vector<int>>::iterator it = vs.begin(); it != vs.end(); ++it){
for (vector<int>::iterator sit = it->begin(); sit != it->end(); ++sit){
cout << *sit << " ";
}
cout << endl;
} } int main(){ //test01();
//test02();
//test03();
test04(); system("pause");
return EXIT_SUCCESS;
}
Vector常用API
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<vector>
using namespace std; void printVector(const vector<int> &vec){
for (vector<int>::const_iterator it = vec.begin(); it != vec.end(); ++it){
cout << *it << " ";
}
cout << endl;
} void printReverseVector(vector<int> &vec){
for (vector<int>::reverse_iterator it = vec.rbegin(); it != vec.rend(); ++it){
cout << *it << " ";
}
cout << endl;
} //1. vector构造
/*
vector<T> v; //采用模板实现类实现,默认构造函数
vector(v.begin(), v.end());//将v[begin(), end())区间中的元素拷贝给本身。
vector(n, elem);//构造函数将n个elem拷贝给本身。
vector(const vector &vec);//拷贝构造函数。 //例子 使用第二个构造函数 我们可以...
int arr[] = {2,3,4,1,9};
vector<int> v1(arr, arr + sizeof(arr) / sizeof(int));
*/
void test01(){ int arr[] = { 2, 3, 4, 1, 9 };
vector<int> v(arr,arr+ sizeof(arr)/sizeof(int)); printVector(v);
printReverseVector(v); vector<int> v2(10, 6);
printVector(v2);
} //2. vector常用赋值操作
/*
assign(beg, end);//将[beg, end)区间中的数据拷贝赋值给本身。
assign(n, elem);//将n个elem拷贝赋值给本身。
vector& operator=(const vector &vec);//重载等号操作符
swap(vec);// 将vec与本身的元素互换。
*/
void test02(){
vector<int> v;
v.assign(10, 6); vector<int> v2;
v2.push_back(1);
v2.push_back(2);
v2.push_back(3); printVector(v);
printVector(v2); cout << "-----------------" << endl;
v.swap(v2);
printVector(v);
printVector(v2); //v.assign(v2.begin(),v2.end());
//printVector(v);
} //3. 大小操作
/*
size();//返回容器中元素的个数
empty();//判断容器是否为空
resize(int num);//重新指定容器的长度为num,若容器变长,则以默认值填充新位置。如果容器变短,则末尾超出容器长度的元素被删除。
resize(int num, elem);//重新指定容器的长度为num,若容器变长,则以elem值填充新位置。如果容器变短,则末尾超出容器长>度的元素被删除。
capacity();//容器的容量
reserve(int len);//容器预留len个元素长度,预留位置不初始化,元素不可访问。
*/ void test03(){ //1. resize开辟空间,并且初始化
//2. reserve只开辟空间,没有初始化
vector<int> v2;
v2.push_back(1);
v2.push_back(2);
v2.push_back(3); cout << "size:" << v2.size() << endl;
v2.resize(5); //改变容器中元素的个数,多余的扔掉
cout << "size:" << v2.size() << endl;
printVector(v2); v2.reserve(20); //预留空间
v2.push_back(10);
printVector(v2);
cout << "size:" << v2.size() << endl;
} void test04(){ vector<int> v;
v.resize(5);
v.push_back(10);
cout << "capacity:" << v.capacity() << endl;
cout << "size:" << v.size() << endl; cout << "----------" << endl;
vector<int> v2;
v2.reserve(5);
v2.push_back(10);
cout << "capacity:" << v2.capacity() << endl;
cout << "size:" << v2.size() << endl; //cout << v2[2] << endl;
} void test05(){ vector<int> v; v.reserve(100000); int *p = NULL;
int count = 0;
for (int i = 0; i < 100000;i ++){
v.push_back(i);
if (p != &v[0]){
p = &v[0];
count++;
}
}
cout << count << endl;
} //swap用法
void test06(){ vector<int> v;
for (int i = 0; i < 100000; i++){
v.push_back(i);
} cout << "容量:" << v.capacity() << endl;
cout << "大小:" << v.size() << endl; cout << "---------------" << endl;
v.resize(10);
cout << "容量:" << v.capacity() << endl;
cout << "大小:" << v.size() << endl; cout << "---------------" << endl;
vector<int>(v).swap(v);
cout << "容量:" << v.capacity() << endl;
cout << "大小:" << v.size() << endl;
} //7. vector数据存取操作
/*
at(int idx); //返回索引idx所指的数据,如果idx越界,抛出out_of_range异常。
operator[];//返回索引idx所指的数据,越界时,运行直接报错
front();//返回容器中第一个数据元素
back();//返回容器中最后一个数据元素
*/
void test07(){ vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3); cout << v.front() << endl;
cout << v.back() << endl; v.front() = 100;
v.back() = 200; for (int i = 0; i < v.size(); i ++){
cout << v[i] << " ";
}
cout << endl;
} //8. vector插入删除
/*
insert(const_iterator pos, int count,ele);//迭代器指向位置pos插入count个元素ele.
push_back(ele); //尾部插入元素ele
pop_back();//删除最后一个元素
erase(const_iterator start, const_iterator end);//删除迭代器从start到end之间的元素
erase(const_iterator pos);//删除迭代器指向的元素
clear();//删除容器中所有元素
*/
void test08(){ vector<int> v;
v.push_back(10);
v.push_back(20);
v.push_back(30);
v.push_back(40); v.insert(v.begin()+2,100);
printVector(v); v.pop_back();
printVector(v);
v.erase(v.begin());
printVector(v);
v.erase(v.begin(),v.end());
cout << "size:" << v.size() << endl; } int main(){ //test01();
//test02();
//test03();
//test04();
//test05();
//test06();
//test07();
test08(); system("pause");
return EXIT_SUCCESS;
}
STL vector常用API的更多相关文章
- C++ vector 常用API
vector: 向量容器,动态数组,类模板 定义和初始化: vector<T> v1; //v1是空vector,元素类型是T类型,执行默认初始化,int为0,string为空串 vect ...
- C++STL -- vector 使用
vector是一种顺序容器. vector常用API: 现在一个个分析: 1. assign 这是一种赋值方法,但是会覆盖原来容器内的值. void assign( size_type num, co ...
- STL之vector常用函数笔记
STL之vector常用函数笔记 学会一些常用的vector就足够去刷acm的题了 ps:for(auto x:b) cout<<x<<" ";是基于范围的 ...
- 2.3 C++STL vector容器详解
文章目录 2.3.1 引入 2.3.2 代码实例 2.3.3 运行结果 总结 2.3.1 引入 vector 容器 动态数组 可变数组 vector容器 单口容器(尾部操作效率高) vector动态增 ...
- C++ STL vector容器学习
STL(Standard Template Library)标准模板库是C++最重要的组成部分,它提供了一组表示容器.迭代器.函数对象和算法的模板.其中容器是存储类型相同的数据的结构(如vector, ...
- java基础3.0:Java常用API
本篇介绍Java基础中常用API使用,当然只是简单介绍,围绕重要知识点引入,巩固开发知识,深入了解每个API的使用,查看JavaAPI文档是必不可少的. 一.java.lang包下的API Java常 ...
- STL vector用法介绍
STL vector用法介绍 介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和f ...
- STL vector 用法介绍
介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通 ...
- C++STL vector详解(杂谈)
介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通 ...
- STL vector简单用法
初涉c++,此为<算法笔记>中的内容,有待个人理解完善. vector vector翻译为向量,叫做"变长数组"更容易理解. 头文件:#include<vecto ...
随机推荐
- 新电脑搭建vue项目步凑
电脑必备软件集合: Chrome,FF Nodejs VS code (ATOM...) GIT || SVN 插件类:postman 美术类:ps,pxcock等,自己喜欢的就行 翻译类:有道词典 ...
- PAT甲级英语单词整理
proper 正确 合适 vertex(vertices)顶点 respectively 个别 分别 indices 指标 索引 shipping 运输 incompatible 不相容 oxidiz ...
- liunx文件定期本地备份、异地备份、删除备份脚本
导航 一.背景二.依赖功能介绍三.本地备份脚本四.异地备份脚本五.定期删除备份六.github脚本地址 - - - - - - - - - - 分割线 - - - - - - - - - - 一.背景 ...
- Windows docker环境安装
前期准备 1.hyper-v功能 win10家庭版没有提供hyper-v的问题可通过如下脚本解决,保存为bat并运行重启电脑即可. pushd "%~dp0" dir /b %Sy ...
- 解决在JS中阻止定时器“重复”开启问题、Vue中定时器的使用
1.问题描述 在一些需求开发中.需要设定软件提供服务的时间段(营业时间).这时可以选择定时器来实现.可以选择让定时器每隔一段时间检测当前时间是否在服务时间.到达服务时间.进入服务状态.未到服务时间.进 ...
- 在vue中的form表单中下拉框中的数据来自数据库查询到的数据
文章目录 1.实现的效果: 2.前端html代码 3.js中的代码 4.后端的方法 1.实现的效果: 增加一个新的类型到数据库 2.前端html代码 需要注意的部分:prop后边是表单中的字段 v-m ...
- 微粒群算法PSO 01背包问题 python
import random import math import matplotlib.pyplot as plt import numpy as np import time def init(b_ ...
- VS使用正则表达式删除程序中的空行
Ctrl+H; 需要替换的正则表达式 ^(?([^\r\n])\s)*\r?$\r?\n
- SpringBoot Starter缘起
SpringBoot通过SpringBoot Starter零配置自动加载第三方模块,只需要引入模块的jar包不需要任何配置就可以启用模块,遵循约定大于配置的思想. 那么如何编写一个SpringBoo ...
- 【原创】All in One i.MXRT1050/RT1020 SPI Flash Algorithm for J-Flash
2020年,这个给大家一种很漫长的恍惚感的一年,终于是过去了.这一年我们很多新的人生第一次就这么被发生了,第一次居家办公这么长时间(很多人肥膘都长了不少,我却瘦了2斤,不知是工作太积极了还是被家里小怪 ...