请问stl中不重复元素也不排序的容器?

Hiiishe 2009-03-31 09:40:35
vector 不自动排序但允许重复
list也是
set有不重复元素的特性,但其自动排序

请问stl中有哪个容器,既如set不重复元素,又不自动排序的?

我只是不想手动判断是否重复。但用set的话,它又会排序。

我用容器装指针, 但我引用时,是按begin,end遍历,我需要按我装入时的顺序访问这些指针。然而set给它的孩子们排序了。
我知道可以用list,vector的push_back,但我不想手动判断压入元素是否重复。
...全文
1244 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
ncucf 2009-04-16
  • 打赏
  • 举报
回复
自己写个保持插入顺序的set就是。
我写过一个CKeepMap,就是多加一个vector<KEY> m_mapstr;维护插入顺序了!
这样在数据量非常多的时候,还是可以保持效率优势,如果每插入一条,就查询一下跟之前的有没有重复,如果是100万条记录的话,O,My god!
bitxinhai 2009-03-31
  • 打赏
  • 举报
回复

这是一个禁止插入重复元素的vector,仅供参考~~~~

#include<vector>
#include<iostream>
using namespace std;

template<typename T>
class SingleElemVector
{
public:
bool push_back(T t)
{
bool flag = false;
for (int i = 0;i < (int)m_TVec.size();i++)
{
if (m_TVec.at(i) == t)
{
flag = true;
break;
}
}

if (flag)
{
return false;
}

m_TVec.push_back(t);
return true;
}

unsigned size()
{
return m_TVec.size();
}
protected:

private:

vector<T> m_TVec;
};



void main()
{
SingleElemVector<int> vec;
vec.push_back(10);
vec.push_back(20);
vec.push_back(30);
vec.push_back(10);

cout<<vec.size()<<endl;

}
bitxinhai 2009-03-31
  • 打赏
  • 举报
回复
这就是你vector插入的时候要
做判断的问题了,
插入时判断vector中是否有这样的元素,
有的话不插入不久可以了
  • 打赏
  • 举报
回复
排序后的找重复的就快
如果不在乎效率的话,用vector然后每次push_back的时候先查找一下.
  • 打赏
  • 举报
回复
比排序找重复的不就慢了?

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧