| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2191 人关注过本帖
标题:从容器中删除元素
只看楼主 加入收藏
thlgood
Rank: 5Rank: 5
等 级:职业侠客
帖 子:281
专家分:381
注 册:2010-9-24
结帖率:91.43%
收藏
已结贴  问题点数:20 回复次数:6 
从容器中删除元素
我是这样编写的:
程序代码:
#include <set>
#include <iostream>
#include <algorithm>
using namespace std;

int main()
{
    set<int>S;
    for(int i = 0; i < 10; i++) {
        S.insert(i);
    }

    S.erase(std::remove(S.begin(), S.end(), 5), S.end());
    set<int>::iterator it;
    for(it = S.begin(); it != S.end(); ++it)
    {
        cout << *it << endl;
    }
    return 0;
}


但是编译的时候老是不通过,G++ 4.6.3的错误提示是:
程序代码:
In file included from /usr/include/c++/4.6/algorithm:63:0,
                 from remove.cpp:3:
/usr/include/c++/4.6/bits/stl_algo.h: 在函数‘_FIter std::remove(_FIter, _FIter, const _Tp&) [with _FIter = std::_Rb_tree_const_iterator<int>, _Tp = int]’中:
remove.cpp:13:46:从此处实例化
/usr/include/c++/4.6/bits/stl_algo.h:1106:13: 错误: 向只读位置‘__result.std::_Rb_tree_const_iterator<_Tp>::operator* [with _Tp = int, std::_Rb_tree_const_iterator<_Tp>::reference = const int&]()’赋值


我的代码有什么问题?我找不出错误啊!
搜索更多相关主题的帖子: set 元素 
2013-05-27 12:16
thlgood
Rank: 5Rank: 5
等 级:职业侠客
帖 子:281
专家分:381
注 册:2010-9-24
收藏
得分:0 
我试过了,如果把set改成vector是可以的。
那set用什么方式删除元素比较合适呢?

o(∩∩)Linux & Python 群:187367181
2013-05-27 12:21
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9007
专家分:53942
注 册:2011-1-18
收藏
得分:7 
remove不能用于关联容器,比如set/map等

S.erase(std::remove(S.begin(), S.end(), 5), S.end()); 你想要的是 S.erase(5) 吗?
2013-05-27 12:51
thlgood
Rank: 5Rank: 5
等 级:职业侠客
帖 子:281
专家分:381
注 册:2010-9-24
收藏
得分:0 
回复 3楼 rjsp
是的。

o(∩∩)Linux & Python 群:187367181
2013-05-27 14:43
子楠
Rank: 3Rank: 3
来 自:武汉
等 级:论坛游侠
帖 子:111
专家分:164
注 册:2013-4-9
收藏
得分:7 
对于容器不懂呀
2013-05-27 16:44
thlgood
Rank: 5Rank: 5
等 级:职业侠客
帖 子:281
专家分:381
注 册:2010-9-24
收藏
得分:0 
找到删除办法了,直接用erase就行了
程序代码:
set<int>S;
...
S.erase(7);


不信的话事后用迭代器遍历一遍!

o(∩∩)Linux & Python 群:187367181
2013-05-27 20:47
hahayezhe
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖南张家界
等 级:贵宾
威 望:24
帖 子:1386
专家分:6999
注 册:2010-3-8
收藏
得分:7 
set的erase 是重载了这个方法 size_type erase(const key_type& _Keyval)可以根据值去删除
要是vector就不能了 必须要传递iter 集合和顺序表是不一样的
2013-05-29 15:35
快速回复:从容器中删除元素
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017247 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved