- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
所以,伙计们,我玩 std::unordered multimap
只是为了好玩。我想存储(在本例中)unsigned short
,带有自定义哈希值和相等值。
有趣的部分是什么?如果两个项目都是偶数或奇数,则两个项目相等。
因此,据我所知,我不能使用 std::unordered_map
,即使实际值不同:自定义谓词另有说明。 (显然,如果我错了,请纠正我!)
回顾一下:我存储不同整数,因此存储不同散列,但它们在谓词下的值可能相同。 p>
#include <iostream>
#include <unordered_map>
class tt
{
public:
tt(const unsigned short v = 0) : i(v) { };
unsigned short i;
};
class tt_hash
{
public:
size_t operator()(const tt &v) const
{
auto f = std::hash<unsigned short>();
return f(v.i);
};
};
class tt_equal
{
public:
bool operator()(const tt &u, const tt &v) const
{
return (u.i % 2) == (v.i % 2);
};
};
typedef std::unordered_multimap<tt, bool, tt_hash, tt_equal> mymap;
// Print all values that match a criteria
void f(const mymap &m, unsigned short c)
{
auto range = m.equal_range(c);
auto target = range.first;
if (target == m.end())
{
std::cout << "not found : " << (int) c << std::endl;
}
else
{
for (auto i = target; i != range.second; i++)
std::cout << "there is : " << (int) i->first.i << " : " << i->second << std::endl;
}
}
int main(int argc, const char * argv[])
{
mymap m;
m.emplace(std::make_pair(tt(3), false));
m.emplace(std::make_pair(tt(10), true));
m.emplace(std::make_pair(tt(4), true));
m.emplace(std::make_pair(tt(23), false));
std::cout << "size " << m.size() << std::endl;
std::cout << "buck " << m.bucket_count() << std::endl;
int c = 0;
for (auto i = m.begin(); i != m.end(); i++)
std::cout << "# " << c++ << " : " << (int) i->first.i << " : " << i->second << std::endl;
f(m, 3);
return 0;
}
所以,当我执行上面的代码时,我找到了正确的值,3、10、4、23(当然不是这个顺序)。
出乎意料的是,当调用 f()
打印所有匹配 3 的值时,我得到了两个答案,3 和 23;但是当我要求 1000 时,我希望打印出所有偶数,但我错了:
size 4
buck 5
# 0 : 4 : 1
# 1 : 10 : 1
# 2 : 3 : 0
# 3 : 23 : 0
there is : 10 : 1
我是不是漏掉了什么? (答案显然是肯定的)
最佳答案
你正在做的是未定义的行为:相等的元素应该有相等的散列值。根据标准(强调我的)
23.2.5 无序关联容器[unord.req]
5 Two values k1 and k2 of type Key are considered equivalent if the container’s key equality predicate returns true when passed those values. If k1 and k2 are equivalent, the container’s hash function shall return the same value for both.
由于您根据模 2 定义等价性,因此您还需要对传递的整数的模 2 使用散列函数。这也意味着只要您拥有 2 个以上的元素,您就需要 std::unordered_multimap
。
关于c++ - 玩 unordered_multimap,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17783622/
我在练习 unordered_multimaps 时遇到了一个问题,一个 unordered_multimap 包含另一个 unordered_multimap。编译器抛出一个错误,说 c++ 标准不
我在这里要疯了。我通过谷歌搜索找到了 1 个不错的示例,其中人们将 unordered_map 与枚举类和哈希函数一起使用,但没有任何运气。我设法找到的那些最终总是说“改用 map ”。 我正在尝试执
我正在尝试使用 boost unordered_multimap 类,但在声明它时遇到了问题。错误跟在代码后面。 #include #include // header file needed f
一本书提到对于std::unordered_multimap: The order of the elements is undefined. The only guarantee is that d
所以,伙计们,我玩 std::unordered multimap 只是为了好玩。我想存储(在本例中)unsigned short,带有自定义哈希值和相等值。 有趣的部分是什么?如果两个项目都是偶数或
我尝试使用以下代码将一个值插入到 boost unordered_multimap 中,但这没有用,因为它无法编译。为什么没有访问 [] 运算符? insert()方法也不行? #include #
我有一个 std::unordered_multimap我想只对每个键进行一次迭代。 我目前正在做的是将所有 key 复制到 std::set .这对我来说似乎效率很低,我想知道是否有更聪明的方法来做
在初始化 boost::unordered_multimap 时,我们定义 HashMap 的大小。 explicit unordered_multimap(size_type n = impleme
我有一个 unordered_multimap 代表一个邻接表,还有几个有自环的边。例如: edges_ 可能是: edges_.insert(Edges::value_type(1, std::ma
我可以使用这段代码将所有元素放入一个桶中: typedef boost::unordered_multimap >
我希望 unordered_multimap::equal_range 具有平均恒定的复杂度,但是以下内容并不像预期的那样随 n 线性扩展: #include #include #include
我想创建一个映射,它使用迭代器作为键类型并使用整数作为值,如下例所示: #include #include int main(int argc, char* argv[]) { typedef
如果我有下面这段代码 std::unordered_multimap> myMap; std::vector v1, v2, v3; // init v1, v2, v3.... myMap.inse
我想构建一个 std::unordered_map,其中的值不是单个字符串、整数或 float ,而是元组、 vector 或结构。我知道这可以像@Vittorio_Romeo 和@CoryKrame
我在调试段错误时遇到问题。我很感激有关如何缩小问题范围的提示。 当迭代器试图访问结构 Infection 的元素时出现错误,定义为: struct Infection { public: expl
我有下面的代码,我知道我几乎是在重新实现容器,但我想这样做,我会有更具体的方法和我不想为不同类型的 multimap 重复代码: template class MapTemplate { public
我想访问/迭代 unordered_multimap 中的所有非唯一键。哈希表基本上是来自签名 的映射。这在实践中确实不止一次发生在标识符上 .我想在哈希表中找到那些出现一次的条目。 目前我使用这
在 boost unordered_multimap 中遍历唯一键的最简单方法是什么。 例如我有这个: std::set used; for (auto p : valuesMap) { if
当key不存在时,unordered_multimap::bucket(key)是什么应该回来吗? 引用资料说它应该返回包含键的桶的桶号,但没有说明当 unordered_multimap 中不存在该
我想知道 std::unordered_multimap 中关键对象的唯一性在处理迭代时。 我将尝试解释这一点:我需要将一些数据与 map 中的键类型相关联,这些数据不应在Hash 中考虑。或 Key
我是一名优秀的程序员,十分优秀!