C++ STL标准程序库初探

来源:互联网 发布:剑侠情缘3网游mac 编辑:程序博客网 时间:2024/05/22 08:14


C++ STL标准程序库初探

  首先解决一个vs2010中按crtl+f5后,CMD闪烁后消失突然消失的问题:

    在你的项目条目(project)上右击鼠标,在弹出菜单上选择最后一项“property/属性,在左边的一栏里找到配置属性->链接器->系统,点击系统项后,在右边的栏的子系统(subSystem将刻项的值配置为"Console(/SUBSYSTEM:CONSOLE)"
    经过这样的配置后,再按 Ctrl+F5,程序运行完毕后就会停留在控制台界面,提示你按任意键继续。 就这样,问题完美解决。 

标准模板库(STL):主要包含3个部分,STL容器,STL 迭代器STL 算法

1STL 容器

顺序容器

std::vectorstd::dequestd::list

关联容器

std::setstd::multisetstd::mapstd::multimap

2STL 迭代器

前向迭代器、双向迭代器、随机访问迭代器

3STL 算法

std::findstd::find_ifstd::reversestd::transform

 

#include <iostream>//标准库#include <vector> //STL容器#include <algorithm> //STL算法using namespace std;int main(){vector<int> v; //v是一个变量, v的类型是vector<int>v.push_back(1);v.push_back(2);v.push_back(34);v.push_back(9);v.push_back(19);    v.push_back(29);    v.push_back(39);v.push_back(49);cout << "向量v里面的数据为: " << endl;vector<int>::iterator i = v.begin();//迭代器初始化的时候指向的是v中的第一个数据元素//由end操作返回的迭代器指向vector的“末端元素的下一个”。通常称为超出末端迭代器(off-the-end iterator),表明它指向了一个不存在的元素。while(i != v.end())//stl中的遍历算法{cout << *i << endl;//迭代器实质上就是一个指针++i;//迭代器在自加,也就是说迭代器在不断的向后移动}//STL中的查找算法vector<int>::iterator iElement = find(v.begin(),v.end(),49);if(iElement != v.end()){int nPosition = distance(v.begin(),iElement);cout << "Value: " << *iElement << endl;cout << "位置: " << nPosition << endl;}return 0;}



运行结果:



beginend操作

    每种容器都定义了一对命名为beginend的函数,用于返回迭代器。如果容器中有元素的话,由begin返回的迭代器指向第一个元素:

vector<int>::iterator iter = v.begin();

上述语句把iter初始化为由名为beginvector操作返回的值。假设vector不空,初始化后,iter即指该元素为v[0]

    end操作返回的迭代器指向vector的“末端元素的下一个”。通常称为超出末端迭代器(off-the-end iterator),表明它指向了一个不存在的元素。如果vector为空,begin返回的迭代器与end返回的迭代器相同。

end操作返回的迭代器并不指向vector中任何实际的元素,相反,它只是起一个哨兵(sentinel)的作用,表示我们已处理完vector中所有元素。

 

 

参考资料:

C++ STL标准程序库

http://blog.sina.com.cn/s/blog_6f3ce2370100qvhh.html



0 0
原创粉丝点击