C++语言程序设计ppt课件.ppt
《C++语言程序设计ppt课件.ppt》由会员分享,可在线阅读,更多相关《C++语言程序设计ppt课件.ppt(27页珍藏版)》请在三一办公上搜索。
1、第十章 C+标准模板库,C+语言程序设计,2,主要内容,泛型程序设计与标准模板库有关的概念和术语C+标准模板库中的容器迭代器标准C+库中的算法函数对象,3,泛型程序设计,将程序写得尽可能通用 将算法从特定的数据结构中抽象出来,成为通用的C+的模板为泛型程序设计奠定了关键的基础 STL是泛型程序设计的一个范例 容器(container)迭代器(iterator)算法(algorithms)函数对象(function object),4,命名空间(namespace),一个命名空间将不同的标识符集合在一个命名作用域(named scope)内为了解决命名冲突例如,声明一个命名空间NS:namspa
2、ce NS class File;void Fun (); 则引用标识符的方式如下,NS: File obj;NS: Fun ();没有声明命名空间的标识符都处于无名的命名空间中,概念和术语,5,命名空间(续),可以用using来指定命名空间例如,经过以下声明:using NS:File;在当前作用域中就可以直接引用Fileusing namespace std;命名空间std中所有标识符都可直接引用在新的C+标准程序库中,所有标识符都声明在命名空间std中,头文件都不使用扩展名,概念和术语,6,容器,容器类是容纳、包含一组元素或元素集合的对象。异类容器类与同类容器类顺序容器与关联容器七种基本
3、容器:向量(vector)、双端队列(deque)、列表(list)、集合(set)、多重集合(multiset)、映射(map)和多重映射(multimap),概念和术语,7,容器的接口,通用容器运算符=,!=,=,=,=方法(函数)迭代方法begin(),end(),rbegin(),rend()访问方法size(),max_size(),swap(),empty(),8,适配器,适配器是一种接口类为已有的类提供新的接口。目的是简化、约束、使之安全、隐藏或者改变被修改类提供的服务集合。三种类型的适配器:容器适配器用来扩展7种基本容器,它们和顺序容器相结合构成栈、队列和优先队列容器迭代器适配
4、器函数对象适配器。,概念和术语,9,迭代器,迭代器是面向对象版本的指针,它们提供了访问容器、序列中每个元素的方法。,概念和术语,10,算法,C+标准模板库中包括70多个算法其中包括查找算法,排序算法,消除算法,记数算法,比较算法,变换算法,置换算法和容器管理等等。这些算法的一个最重要的特性就是它们的统一性,并且可以广泛用于不同的对象和内置的数据类型。,概念和术语,11,顺序容器,顺序容器的接口插入方法push_front(),push_back(),insert(),运算符“=”删除方法pop() ,erase(),clear()迭代访问方法使用迭代器其他顺序容器访问方法(不修改访问方法)fr
5、ont(),back(),下标运算符,容 器,12,顺序容器向量,向量属于顺序容器,用于容纳不定长线性序列(即线性群体),提供对序列的快速随机访问(也称直接访问)向量是动态结构,它的大小不固定,可以在程序运行时增加或减少。例10-1求范围2N中的质数,N在程序运行时由键盘输入。,容 器,/10_1.cpp#include #include #include /包含向量容器头文件using namespace std ;int main() vector A(10); int n; int primecount = 0, i, j; cout=2 as upper limit: ; cin n;
6、 Aprimecount+ = 2;,13,for(i = 3; i i/2) Aprimecount+ = i; for (i = 0; iprimecount; i+)/输出质数 coutsetw(5)Ai; if (i+1) % 10 = 0) /每输出10个数换行一次 cout endl; coutendl;,14,15,顺序容器双端队列,双端队列是一种放松了访问权限的队列。元素可以从队列的两端入队和出队,也支持通过下标操作符“”进行直接访问。例10-2使用双端队列容器保存double数值序列,容 器,16,顺序容器列表,列表主要用于存放双向链表,可以从任意一端开始遍历。列表还提供了拼
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C+ 语言程序设计 ppt 课件
链接地址:https://www.31ppt.com/p-2002751.html