cb08a_c++_顺序容器的操作1
cb08a_c++_顺序容器的操作1
容器定义的类型别名
begin(闭区间)和end(开区间)成员
{first,last)左闭右开,左包括,右不包括,end()指向最后一个的下一个。
- /*cb08a_c++_顺序容器的操作1
- 容器定义的类型别名
- begin(闭区间)和end(开区间)成员
- {first,last)左闭右开,左包括,右不包括,end()指向最后一个的下一个。
- */
- #include <iostream>
- #include <vector>
- #include <list>
- #include <deque>
- using namespace std;
- int main()
- {
- vector<int> a;
- list<int> b; //链表没有下表,不能用数组表示
- deque<int> c;
- //error C2663: “std::vector<int,std::allocator<_Ty>>::push_back”: 2 个重载没有“this”指针的合法转换
- //ca.push_back(11);//const vector不能直接放数据
- a.push_back();
- a.push_back();
- a.push_back();
- const vector<int> ca(a);//const可以通过非const vector传入数据,进行初始化。类似于:ca=a;
- b.push_back();
- b.push_back();
- b.push_back();
- c.push_back();
- c.push_back();
- c.push_back();
- //for(int i=0;i<a.size();++i)//不要使用,因为int类型不够大,可能vector数据会超出。
- for (vector<int>::size_type i = ; i < a.size(); ++i)
- cout << a[i] << endl;
- ////链表没有下表,不能用数组表示
- /*for (list<int>::size_type k = 0; k < b.size(); ++k)
- cout << b[k] << endl;*/
- for (deque<int>::size_type j = ; j < c.size(); ++j)
- cout << c[j] << endl;
- //链表只能用迭代器
- vector<int>::iterator firsta = a.begin();
- vector<int>::iterator lasta = a.end();//end()指向最后一个的下一个
- vector<int>::const_iterator cfirsta = ca.begin();//const_iterator,const迭代器,操作const vector容器
- vector<int>::const_iterator clasta = ca.end();
- while (firsta != lasta)
- {
- cout <<"迭代器循环: "<< *firsta << endl;
- ++firsta;
- }
- vector<int>::reverse_iterator rfirsta = a.rbegin();//rbegin()逆序迭代器
- vector<int>::reverse_iterator rlasta = a.rend();//rend()逆序迭代器
- vector<int>::size_type a1;
- vector<int>::iterator a2;
- vector<int>::const_iterator a3;
- vector<int>::reverse_iterator a4;//逆序迭代器
- vector<int>::const_reverse_iterator a5;
- vector<int>::difference_type a6;//保存容器之间距离
- //泛型程序设计
- //vector<int>::value_type a7;
- //vector<int>::reference a8;//引用
- //vector<int>::const_reference a9;
- list<int>::size_type b1;
- list<int>::iterator b2;
- list<int>::const_iterator b3;
- list<int>::reverse_iterator b4;
- list<int>::const_reverse_iterator b5;
- list<int>::difference_type b6;
- /*list<int>::value_type b7;
- list<int>::reference b8;
- list<int>::const_reference b9;*/
- deque<int>::size_type c1;
- deque<int>::iterator c2;
- deque<int>::const_iterator c3;
- deque<int>::reverse_iterator c4;
- deque<int>::const_reverse_iterator c5;
- deque<int>::difference_type c6;
- /*deque<int>::value_type c7;
- deque<int>::reference c8;
- deque<int>::const_reference c9;*/
- cout << "hello..." << endl;
- return ;
- }
cb08a_c++_顺序容器的操作1的更多相关文章
- cb14a_c++_顺序容器的操作7_赋值与交换(swap)_vector转list
cb14a_c++_顺序容器的操作7_赋值与交换(swap) vector数据赋值给list, slist.assign(svec.begin(), svec.end());//这样可以转 svec- ...
- ca13a_c++_顺序容器的操作6删除元素
/*ca13a_c++_顺序容器的操作6删除元素c.erase(p) //删除迭代器p指向的位置c.erase(b,e) //删除b to e之间的数据,迭代器b包括,e不包括c.clear()//删 ...
- cb11a_c++_顺序容器的操作4_容器大小操作_resize-max_size
cb11a_c++_顺序容器的操作4 2 容器大小的操作 3 c.size() 容器当前的个数 4 c.max_size(),容器最大存储量 5 c.empty() 是否为空 6 c.resize(n ...
- cb10a_c++_顺序容器的操作3关系运算符
cb10a_c++_cb09a_c++_顺序容器的操作3 2 顺序容器的操作3 3 关系运算符 4 所有的容器类型都可以使用 5 比较的容器必须具有相同的容器类型,double不能与int作比较 6 ...
- cb09a_c++_顺序容器的操作2-在顺序容器中添加元素_插入数据
cb09a_c++_顺序容器的操作2在顺序容器中添加元素vector不能向前插入数据,list可以用insertc.push_back(t);c.push_front(t);c.insert(p,t) ...
- cb16a_c++_顺序容器的选用_排序_二分查找
/*cb16a_c++_顺序容器的选用_排序_二分查找顺序容器: 1.vector的优点与缺点 vector优点:排序利用下标,快速排序,做二分查找非常快 2.list的优点与缺点 list优点:插入 ...
- ca12a_c++顺序容器的操作5_访问容器中的数据元素
ca12a_c++顺序容器的操作5_访问容器中的数据元素访问元素:c.back()..显示最后一个数据c.front() ..显示第一个数据c[n],n就是下标,适合vector与dequec.at( ...
- cb06a_c++_顺序容器的定义
/*cb06a_c++_顺序容器的定义顺序容器:vector,数组,尾端操作数据,快速随机访问list 链表,快速插入数据deque数组,双端-首尾操作数据,方便两端的数据访问 顺序容器适配器:sta ...
- cb03a_c++_数据结构_顺序容器_STL_stack
/*cb03a_c++_数据结构_顺序容器_STL_stack堆栈:LIFO--Last In First Out后进先出,用于系统程序设计自适应容器(容器适配器),不是独立的容器,是一个适配器栈适配 ...
随机推荐
- Mysql与Mysqli的区别及特点
1)PHP-MySQL 是 PHP 操作 MySQL 资料库最原始的 Extension ,PHP-MySQLi 的 i 代表 Improvement ,提更了相对进阶的功能,就 Extension ...
- C#网络编程入门之TCP
目录: C#网络编程入门系列包括三篇文章: (一)C#网络编程入门之UDP (二)C#网络编程入门之TCP (三)C#网络编程入门之HTTP 一.概述 UDP和TCP是网络通讯常用的两个传输协议,C# ...
- [ubuntu][mysql 5.7]安装后没有密码?如何登录
环境:(2020-04-21) WSL ubuntu LTS 18.04.1 mysql Ver 14.14 Distrib 5.7.29, for Linux (x86_64) 找到随机密码 # 显 ...
- 大O符号初学者指南
原文地址:https://rob-bell.net/2009/06/a-beginners-guide-to-big-o-notation/ 计算机科学中,大O表示法被用来描述一个算法的性能或复杂度. ...
- 【Ubuntu】Ubuntu中下载特定版本内核和设置某版本内核为默认启动内核
0. 基本命令 uname -a # 查看当前所使用内核 dpkg -l | grep linux # dpkg后是lmn的l.查看当前操作系统的内核 dekg -l | grep linux-ima ...
- SD.Team主题形象小人偶
W e ♥ S D ♫ ♪ 咔咔咔~可能源码冲突会造成小人偶光头 :)
- Java实现 LeetCode 268 缺失数字
268. 缺失数字 给定一个包含 0, 1, 2, -, n 中 n 个数的序列,找出 0 - n 中没有出现在序列中的那个数. 示例 1: 输入: [3,0,1] 输出: 2 示例 2: 输入: [ ...
- Java实现 LeetCode 33 搜索旋转排序数组
33. 搜索旋转排序数组 假设按照升序排序的数组在预先未知的某个点上进行了旋转. ( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] ). 搜索一个给定的目标值, ...
- Java实现 洛谷 P1115 最大子段和
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scann ...
- Java实现 洛谷 P1421 小玉买文具
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner in = ...