博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vector容器与find算法
阅读量:6160 次
发布时间:2019-06-21

本文共 1403 字,大约阅读时间需要 4 分钟。

from: http://blog.csdn.net/huangyimin/article/details/6133650


好多东西学了过段时间就忘,忘了再搜索再学。也许人一生忘记是硬道理,学习也是硬道理吧!见到下面的短文很好,便引用到此,以备后忘!!!

stl包括容器、迭代器和算法

容器

用于管理一些相关的数据类型。每种容器都有它的优缺点,不同的容器反映出程序设计的不同需求。容器自身可能由数组或链表实现,或者容器中的每个元素都有特殊的关键值。

迭代器

用于遍历一个数据集中的每个元素。这些数据集可能是容器或者容器的子集。迭代器的主要优点是它们为任意类型的容器提供一个小巧并且通用(注意通用很重要) 的接口。例如,迭代器接口的一个操作是让它依次遍历数据集的每个元素。这个操作是依赖容器的内总部结构独立完成的。迭代器之所以有效是因为容器类提供它自 己的迭代器类型来做“正确的事”,容本身的迭代器了解容器的内部结构。

迭代器的接口几乎相当于普通的指针。让一个迭代器递增只需调用++操作符。使用*操作符可以得到迭代器引用的数据值。因而迭代器可以被任为是一种智能指针。

算法

被用于处理数据集中的元素。例如它们可以搜索、排序、修改数据或者其他目的。算法使用迭代器,因此,一个算法只需被编写一次就可以用于任意的容器,因为迭代器的接口对所有类型的容器是通用的。这就是find()的位置。

为了给算法更多的扩展性,需要提供一些被算法调用的附属函数。可以使用通用算法去适应非常特别和复杂的需求。你可以提供自己的搜索标准或者特殊的操作去绑定元素。

STL的概念是将数据和操作独立开来。数据由容器类管理,而操作是由可配置的算法定义。迭代器则是这两个元素之间的线索。它允许任何算法和容器的交互。

在某种意义上,STL的概念有勃于面向对象编程的初衷:STL将数据和算法分离而非绑定它们。然而,这样做的理由非常重要:原则上,你可以将任何容器同任何算法绑定,得到的结果是STL是非常可扩展的。

STL的一个标准是它支持任意数据类型。“标准模板库”意味着,所有部分是适应任意类型的模板。STL是通用编程的例子。容器和算法对任意类型和类都是通用的。

STL甚至提供更多的通用组件。使用 适配器 和函数体,你可以为特定需要补充、限制和配置算法和接口。

例子

一个find Vector的例子(BAIDU里找的),注意find不属于vector的成员,而存在于算法中,应加上头文件#include <algorithm>:

#include <vector>

#include <algorithm>
#include <iostream>
int main( )
{
    using namespace std;
    vector<int> L;
    L.push_back( 1 );
    L.push_back( 2 );
    L.push_back( 3 );
    L.push_back( 4 );
    L.push_back( 5 );
    vector<int>::iterator result = find( L.begin( ), L.end( ), 3 ); //查找3
    if ( result == L.end( ) ) //没找到
        cout << "No" << endl;
    else //找到
        cout << "Yes" << endl;
}

你可能感兴趣的文章
Git 初次学习笔记
查看>>
Java线程:线程交互
查看>>
dbms_metadata.get_ddl的使用总结
查看>>
修改SSO管理员密码
查看>>
QCwindows server 2003部署
查看>>
批量修改密码脚本
查看>>
关于盘符里某些文件夹删除不了的解决方案研究
查看>>
lzg_ad:XPE操作系统镜像尺寸优化
查看>>
GlusterFS架构与维护
查看>>
全天下最经典的句子,2013重现!
查看>>
Microsoft Windows 7.0 build 7000 NAP测试--健康状态检测验证报告
查看>>
容器间通信的三种方式 - 每天5分钟玩转 Docker 容器技术(35)
查看>>
Linux权限管理总结(1)--基础权限
查看>>
sql server常用函数
查看>>
64位Outlook 无法与OC集成
查看>>
Unity3d切水果,坦克,投篮游戏视频
查看>>
Linux命令TOP TEN
查看>>
多样化实现Windows Phone 7本地数据访问<3>——DB4O
查看>>
PHP设计模式(6)迭代器模式
查看>>
基于Web Services建立Asp与Asp.Net之间Session数据桥的应用研究
查看>>