- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
问题:您将如何编写一个函数来为 map 构造函数执行自定义比较器以创建特定的键顺序?
我有以下字符串键:
"a", "d", "i", "n", "ns", "ne", "vl", "rr"
我正在使用 map 为这些键写入值。但我需要按照上述确切顺序订购它们。 Map 通常创建顺序:
a d i n ne ns rr vl
如何编写可以发送到 map 构造函数的比较器函数,以便我可以保持此顺序?
这是我目前使用的方法
vector<pair<string, string>>({ { "a","" },{ "d","" },{ "i","" },{ "n","" },{ "ns","" },{ "ne","" },{ "vl","" },{ "rr","" }, { "","" } });
...然后我做了一堆 find_if 调用。如果找到,我将值添加到该对中。如果没有,我创建一对新的(在开始时)。我在一开始就这样做,所以如果 key 不存在,我可以只返回“”。好吧,除了我需要对上面没有列出的键进行排序外,这一切都有效,因为可以添加任何键。此外,当我尝试添加一个不存在的 key 时,我的程序崩溃了。必须调试它......但是这种方式令人困惑。使用带有一些特定排序的 map 将非常适合我的需要(在运行时添加的任何键都应该通过默认比较进行排序以及维护顺序。但是可以对这些“未知”( future 添加的)键进行排序) .
我“想要这个”的原因(在评论中提出):我需要在程序的最后一步输出这样的字符串:
",a=legato,d=dn,i=12,n=A3"
等它们需要按特定顺序排列,因为我稍后需要使用正则表达式(在单独的程序中)来操作此字符串。顺序对于指定的键很重要。由于正则表达式,还必须为未指定的键固定顺序。
最佳答案
您将映射用于排序键的比较器指定为模板参数。所以你的 map 声明看起来像:
std::map<string, value_type, my_comparator> my_map;
比较器是你可以定义的东西,它接受两个 key_type
参数 a
和 b
,如果 a
出现在 b
之前(否则为 false)。这方面的一个例子是:
struct my_comparator {
bool operator()(const string &a, const string &b) {
// Return true if a comes before b.
}
}
要实现您在问题中指定的顺序,您可以按照以下方式进行操作。我使用 std::tuple
来确保满足严格的排序标准。
bool operator()(const string &a, const string &b) {
auto a_tuple = std::make_tuple(a == "a", a == "d", a == "i", ..., a);
auto b_tuple = std::make_tuple(b == "a", b == "d", a == "i", ..., a);
return a_tuple < b_tuple;
}
因为这在元组的最后一个元素中有 a
和 b
,如果它与您的预定义字符串之一不匹配,它将按这些排序。
关于C++ Comparator 函数指定映射的特定键顺序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33338227/
我经常有一个 Comparator 类型,而我需要一个 Comparable 类型,反之亦然。是否有可重用的 JDK API 可以相互转换?类似的东西: public static Comp
我怎么能写这个 Comparator sort = (i1, i2) -> Boolean.compare(i2.isOpen(), i1.isOpen()); 像这样(代码不起作用): Compa
请帮助她。我有一个错误 Collections.sort(var4, new Comparator() { public int compare(TreeMap var1, TreeMa
学习 Kotlin,我试图了解 Java 的 Comparator接口(interface)有效 - 主要是 compare() 函数,这样我就可以利用它。 我已经尝试阅读 compare() 的文档
我有以下程序 List numbers = Arrays.asList("10", "68", "97", "9", "21", "12"); Collections.sort(numbers, (
我想根据嵌套类的属性对如下所示的列表进行排序。 class Test { private NestedClass nestedClass; private AnotherNes
我很好奇“Beyond Compare”的算法是如何工作的? 我猜想他们使用了一种标准的(众所周知的?)算法来实现“字符与字符”的比较。你知道这个算法的名字吗?谢谢 最佳答案 Beyond Compa
这个问题已经有答案了: How does the sort() method of the Collection class call the Comparable's compareTo()? (1
这个问题已经有答案了: 已关闭12 年前。 Possible Duplicates: difference between compare() and compareTo() Java: What i
我被要求为某个类实现Comparable或Compartor,我们称之为V。 假设我有一个 V 的 Collection 或 Set(还不确定,但我认为这并不重要)。 V 有一个方法,可以评估它的“权
我正在查看Java8中实现的Comparator.comparing方法的源代码 这是代码 public static Comparator comparing( Function
假设我有一个类 ClassA,它的属性是 ClassB: public ClassA { private String attr; private ClassB classB; } p
我有一个自定义比较器,其比较逻辑如下: List l = new ArrayList(); l.add("tendercoupon"); l.add("giftcard
我正在努力实现一个处理 Comparator 和 Comparable 接口(interface)的层次结构。我不清楚的几件事: 如果我将比较器添加到比较器链中,这段代码究竟意味着什么 chain.a
正在关注 this question关于按另一个列表对列表进行排序,我尝试做同样的事情 - 但由于某种原因它对我不起作用。我错过了什么? List nums = Arrays.asList(5
假设我有一个像这样的领域模型: class Lecture { Course course; ... // getters } class Course { Teache
在表达式 > 中像这样的签名 public static > foo(T x) { ... } T的描述递归地依赖于Comparable . 如果T延伸Comparable ,和Comparable延
所有“数字”比较器(例如 Comparer.Default 、 Comparer.Default 等)返回 -1 的原因是什么? , 0或 1 ,但是 Comparer.Default和 Compar
(如果这是重复的,请指出正确的答案!我搜索并阅读了几个(> 5)个相关问题,但似乎没有一个是正确的。还查看了泛型常见问题解答和其他来源...) 当一个集合类接受一个比较器时,它应该具有 Compara
SBCL 1.3.1 综上所述,a是一个列表,'(7),b通过setq sbcl This is SBCL 1.3.1.debian, an implementation of ANSI Common
我是一名优秀的程序员,十分优秀!