gpt4 book ai didi

c++自定义映射键/值不按顺序

转载 作者:行者123 更新时间:2023-11-30 05:48:35 25 4
gpt4 key购买 nike

我使用自定义结构构建了以下 map 。

#include <iostream>
#include <vector>
#include <map>

struct keys {
int first;
int second;
int third;
};

struct keyCompare
{
bool operator()(const keys& k1, const keys& k2)
{
//return (k1.first<k2.first && k1.second<k2.second && k1.third<k2.third);
return (k1.first<k2.first || k1.second<k2.second || k1.third<k2.third);
//return (k1.first<k2.first || (k1.first==k2.first && k1.second<k2.second) || (k1.first==k2.first
// && k1.second==k2.second && k1.third<k2.third));
}
};

int main()
{
keys mk, mk1;
int len = 4;
//int myints1[9] = {1,2,3,4,5,6, 7,8,9};
int myints1[12] = {1,2,3,4,5,6,1,2,3,1,2,3};
std::vector<int> input1(myints1, myints1+12);

std::map<keys, int, keyCompare> c2int;

for (int i = 0; i < len; i++) {
mk.first = input1[i*3];
mk.second = input1[i*3+1];
mk.third = input1[i*3+2];
c2int[mk] = i;
}

for (int i = 0; i < len;i++) {
mk1.first = input1[i*3];
mk1.second = input1[i*3+1];
mk1.third = input1[i*3+2];
std::cout << "map content " << c2int[mk1] << "\n";
}

return 0;}

对于非重复键,如 {1,2,3,4,5,6,7,8,9},代码按预期工作。返回是

map content is 0
map content is 1
map content is 2

但是当存在重复模式时,例如,键是 {1,2,3,4,5,6,1,2,3}。打印出来的是

map content is 2
map content is 1
map content is 2

在我期待的时候

map content is 0
map content is 1
map content is 0

因为键 {1,2,3} 已经分配了值 0。但是比较函数似乎将此键修改为值 2 而不是 0。我尝试了不同的比较函数,但没有一个显示预期的输出。我想我在这种方法中遗漏了一些东西。有人可以解释吗?谢谢

最佳答案

这个比较器不正确:

bool operator()(const keys& k1, const keys& k2) 
{
return (k1.first<k2.first || k1.second<k2.second || k1.third<k2.third);
}

考虑 {1,4,9}对比{2,3,4} . {1,4,9} < {2,3,4}因为第一次比较,然后{2,3,4} < {1,4,9}因为第二个!这显然不是你想要的!此外,operator<必须是不对称的才能成为 StrictWeakOrdering ,这是 std::map 所需要的.

你必须按顺序处理键:

bool operator()(const keys& k1, const keys& k2) {
if (k1.first != k2.first) {
return k1.first < k2.first;
}
else if (k1.second != k2.second) {
return k1.second < k2.second;
}
else {
return k1.third < k2.third;
}
}

关于c++自定义映射键/值不按顺序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28132602/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com