【发布时间】:2014-03-09 00:03:03
【问题描述】:
是否可以实现散列,其中键为String,值为function。作为背景,我有一个程序,其中有很多字符串比较,即
if(strcasecmp(s,"london")==0)
functionA();
else if(strcasecmp(s,"moscow")==0)
functionB();
else if(strcasecmp(s,"delhi")==0)
functionC();
...
等等。
但是这种实现是非常昂贵的(theta(n)),因为String 比较是针对所有if 语句进行的。如果我们有一个哈希实现,其中键是String,值是function,我们可以调用类似
function = hash.Get("moscow");
function();
它的复杂度很好(theta(log(1)))。
可以这样做吗?
【问题讨论】:
-
std::map是您要找的。span> -
或者
std::unordered_map,如果复杂度应该是O(1)和散列O(m)。