zoukankan
html css js c++ java
STL中用erase()方法遍历删除元素
STL中的容器按存储方式分为两类,一类是按以数组形式存储的容器(如:vector 、deque);另一类是以不连续的节点形式存储的容器(如:list、set、map)。在使用erase方法来删除元素时,需要注意一些问题。
在 使用 list、set 或 map遍历删除某些元素时可以这样使用:
正确使用方法1
std::list< int> List;
std::list< int>::iterator itList;
for( itList = List.begin(); itList != List.end(); )
{
if( WillDelete( *itList) )
{
itList = List.erase( itList);
}
else
itList++;
}
在使用 vector、deque遍历删除元素时,也可以通过erase的返回值来获取下一个元素的位置:
正确使用方法
std::vector< int> Vec;
std::vector< int>::iterator itVec;
for( itVec = Vec.begin(); itVec != Vec.end(); )
{
if( WillDelete( *itVec) )
{
itVec = Vec.erase( itVec);
}
else
itList++;
}
查看全文
相关阅读:
C# winform 学习(三)
(Java实现) 均分纸牌
(Java实现) 拦截导弹
Delphi从内存流中判断图片格式(好多相关文章)
Qt之QTableView显示富文本(使用了QAbstractTextDocumentLayout和QTextDocument)
MAC和PHY的区别(网线上传递的是模拟信号)
Qt之模型/视图(自定义按钮)(重绘QStyleOptionButton)
QQ音乐的请求
Log4j、Log4j 2、Logback、SFL4J、JUL、JCL的比较
LRU Cache
原文地址:https://www.cnblogs.com/tuzhiye/p/1688326.html
最新文章
在Qt中将函数发送到主线程执行
如何让窗口控件半透明(控件在Paint自己时,首先向主窗口询问,获取主窗口上控件所在区域的背景图)
Web.Config Transformation配置灵活的配置文件
JavaScript插件——模态框
C#项目代码规范
WebForm和Asp.Net MVC的理解
Bug Tracker
require.js实践
Bootstrap3.0(进度条、媒体对象、列表组、面板)
Controller 和 Action (2)
热门文章
ESB与SOA的关系
Bootstrap3.0学习第十五轮(大屏幕介绍、页面标题、缩略图、警示框、Well)
[Ext JS 4] contentEL,renderTo, applyTo 释义与区别
C# winform 学习(三)
C# Winform学习(六)
C# Winform 学习(五)
(Java实现) 洛谷 P1691 有重复元素的排列问题
C# winform 学习(一)
C# winform 学习(二)
C# Winform 学习(四)
Copyright © 2011-2022 走看看