首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ACL2中的排序映射

ACL2中的排序映射
EN

Stack Overflow用户
提问于 2014-11-10 11:50:53
回答 1查看 46关注 0票数 0

我必须在ACL2中使用排序的映射/索引结构。目前,我有以下几点:

代码语言:javascript
复制
( (key1 . (val1 val2)) (key2 . (val3)) (key3 . (val4 val5 val6)) )

还有其他更有效的方法吗?

EN

回答 1

Stack Overflow用户

发布于 2014-11-24 01:30:27

从你的例子来看,我不清楚你想做什么。

当然,您可以在关联列表上定义操作,使其保持按键排序的顺序。在这种情况下:

  • 您的get函数看起来就像acons
  • 您的put函数需要查找放置元素的“正确”位置。

但这并不是特别有效。这两项行动都是O(n)。另外,作为一个实际考虑,put操作将需要O(n)会话,这是特别昂贵的,因为cons分配内存。

通常情况下,最好只使用普通的关联列表,即使用aconsassoc。主要的优点是,由于它简单地将新的键/值对转换到列表的前面,所以acons是O(1),所以构造映射通常要便宜得多。如果需要的话,您可以随时对列表中的键进行排序,例如,使用集合:合并或某些自定义排序函数。

访问参与者仍然是O(n)。然而,快速主义者在ACL2(h)中是可用的,本质上提供了一种获得哈希表速度的方法。还请参阅性病/医务人员的文档。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26843201

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档