温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

删除C++容器值相关方法是怎么样的

发布时间:2021-10-27 18:58:42 来源:亿速云 阅读:143 作者:柒染 栏目:编程语言

这期内容当中小编将会给大家带来有关删除C++容器值相关方法是怎么样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

在程序开发的过程中,C++编程语言中的容器里有会有很多值,有些是比较有用的,而有些是没用的。那么对于这些没有用的值我们应该如何进行删除呢?在这里我们将会为大家详细介绍删除C++容器值的相关方法。

C++的容器中一般都提供erase函数,此函数接收的参数一般有一个是一个迭代器:

如果删除C++容器值的话,我们可能一般都用过:

list<int> c;  // todo insert items  for (list<int>::iterator i = c.begin(); i!= c.end(); ++i)  {  if ((*i)>10)  {  // 如果有一个值大于10,删除之  c.erase(i);  break;  }  }

上述代码在删除一个元素的时候并没有问题。。。但是我们想删除所有大于10的值,于是:

list<int> c;  // todo insert items  for (list<int>::iterator i = c.begin(); i!= c.end(); ++i)  {  if ((*i)>10)  {  // 删除所有大于10的值  c.erase(i);  }  }

满怀希望的编译,运行。。。于是异常发生。。。啊。。。哦。。。

原来是删除迭代器i后,i所指的元素已经失效了,然后给i++,它已经不在存在了。。。于是绞尽脑汁,出笼了下面的删除C++容器值代码:

list<int> c;  // todo insert items  list<int>::iterator nextitr = c.begin();  for (list<int>::iterator i = c.begin();;)  {  if(nextitr == c.end())  break;  ++nextitr;  if ((*i)>10)  {  // 如果有一个值大于10,删除之  c.erase(i);  }  i = nextitr;  }

上面的代码很容易理解,即在删除一个迭代器之前,把它的之后的迭代器先存储,然后在下次循环的时候利用之前存储的迭代器。

OK,我们看到上面这段代码可以工作了,行为似乎也还正确,只是。。。代码似乎多了点。我想代码能够少点就好了,逻辑也不要那么麻烦。那么我们看下面的代码(转载自Effective STL)。

list<int> c;  // todo insert items  for (list<int>::iterator i = c.begin(); i!= c.end();)  {  if ((*i)>10)  {  // 如果有一个值大于10,删除之  c.erase(i++);  }  else  i++;  }

嗯。。。高手就是高手(我以前根本没有在意过++i和i++在使用的过程中能有这么大的区别)好了,***再提供一个版本,利用list的remove_if函数。

bool fun(int i)  {  if(i>10)  return true;  else  return false;  }  list<int> c;  // todo insert items  c.remove_if(fun);

嗯,其实删除C++容器值的方式还是挺多的。

上述就是小编为大家分享的删除C++容器值相关方法是怎么样的了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++
AI