c++ list 正确删除

 

c++  std::list 是一个双向链表,对它的遍历大部分都是使用list<T>::iterator it;大致的结构如下:

下面的简单代码是去除链表中小于1000的值,关键在于it =ListNumber->erase(it); 需要返回it,因为it是正在遍历的指针;删除后就无法继续遍历后面的队列了,会报错;

ListNumber->erase(it++);也可以; 

list<int> ListNumber;
///.........
list<int>::iterator it;
int min = 0;
for (it = ListNumber->begin(); it != ListNumber->end(); )
{
	min = (*it) - 1000;
	if (min < 0 )
	{
		it =ListNumber->erase(it);
         //ListNumber->erase(it); 错误
        //ListNumber->erase(it++);正确
	}else{
		it++;
	}
			
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值