我想知道什么数据结构(内置的或非内置的)对于访问接受5个条件作为输入的数据是最优的。
例如:
if (cond_a == 2) & (cond_b == 3) ... (cond_e == 6):
value = 5
我主要考虑的是速度,而不是内存效率。这5个条件之间没有关系(它们彼此独立)。但是,对于每个条件,一个项可以有多个值-数据结构将返回值的可迭代值。
我在考虑使用嵌套有序字典(5层深)--有没有更好的选择?
编辑-这5个条件的所有组合不一定都有唯一的值。对于某些条件组合,更改该组合中的一个条件可能不会更改最终值。
发布于 2020-05-06 04:48:55
如果您总是想要匹配所有五个条件的值,请使用带有5元组作为键的单个字典。
from typing import Dict, Tuple
data: Dict[Tuple[int, int, int, int, int], int] = {
(2, 3, 4, 5, 6): 5
}
value = data[(cond_a, cond_b, cond_c, cond_d, cond_e)]
如果您希望能够对仅匹配某些条件的值进行查询,那么我认为您将需要多个字典(而不是嵌套的,将值存储在集合中,以便您可以进行交集)。
https://stackoverflow.com/questions/61622742
复制相似问题