- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个包含汇率值的 OrderedDictionary。每个条目都有一个键的日期(每个日期恰好是每年一个季度的开始),值是一个数字。日期按从旧到新的顺序插入。
{
date(2017, 1, 1): 95,
date(2018, 1, 1): 100,
date(2018, 6, 1): 110,
date(2018, 9, 1): 112,
}
我的利率词典比这个大得多,但这是一般的想法。给定一个任意日期,我想在字典中找到它之前的值。。例如,查找 date(2018, 8, 1)
的日期应返回值 110,因为条目 date(2018, 6, 1)
是我的日期查找之前最近的键。同样,日期 date(2017, 12, 1)
应该返回 95,因为最近的前一个键恰好是 date(2017, 1, 1)
.
我可以通过遍历字典中的项目轻松地做到这一点:
def find_nearest(lookup):
nearest = None
for d, value in rates.items():
if(d > lookup):
break
nearest = value
return nearest
然而,这对我来说感觉效率很低,因为在最坏的情况下我必须扫描整个字典(我之前提到过它可能很大)。我将进行数以万计的此类查找,因此我希望它具有高性能。
解决性能问题的另一种选择是为我所见创建一个缓存,这也是可行的,尽管我想知道内存限制(我不完全确定缓存会增长到多大)。
我可以在这里使用任何巧妙的方法或 Python 核心模块吗?
最佳答案
由于您按顺序将日期插入到字典中,并且您可能使用的是 Python 3.7(这使得字典顺序很重要),因此您可以使用分而治之的递归函数在 O 中找到所需的键列表索引(log n) 时间复杂度:
def find_nearest(l, lookup):
if len(l) == 1:
return l[0]
mid = len(l) // 2
if l[mid] > lookup:
return find_nearest(l[:mid], lookup)
return find_nearest(l[mid:], lookup)
这样:
from datetime import date
d = {
date(2017, 1, 1): 95,
date(2018, 1, 1): 100,
date(2018, 6, 1): 110,
date(2018, 9, 1): 112,
}
d[find_nearest(list(d), date(2018, 8, 1))]
返回:110
关于python - 有效地找到 OrderedDictionary 中的上一个键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52535803/
在我的应用程序中,我实现了一些控件 以不同方式浏览数据。在每个控件中,我都显示一个 TreeView 以允许用户从一个文件夹转到另一个文件夹。 我希望我的控件以通用方式“记住”最后选择的树(我的意思是
我对 orderedDictionary 和 Regex 有疑问。我如何通过文本定义问题,但我会尝试解释... 这是我的代码: var smilies = new OrderedDictionary
没有人说 OrderedDictionary 有两个元素副本,一个在哈希表中,另一个在列表中,我在 MSDN 上找不到 OrderedList 的复杂性度量。 谢谢 最佳答案 看看 OrderedDi
我一直在寻找一种方法来拥有我的 Dictionary枚举其KeyValuePair按照添加它们的顺序。现在,Dictionary's documentation明确指出: For purposes o
我尝试以后进先出的顺序迭代有序字典。虽然对于标准字典来说一切正常,但orderedDict的第一个解决方案 react 很奇怪。看来,虽然 popitem() 返回一个键/值对(但不知何故按顺序,因为
我如何遍历 OrderedDictionary反过来访问它的 key ? 由于它不支持 LINQ 扩展,我尝试了以下方法: var orderedDictionary= new OrderedDict
在我的 OrderedDictionary 中,我想替换一个对象。我看到 OrderedDictionary 有一个名为 Insert() 的方法。所以,我想当我获得要替换的对象的索引时,我使用 Re
在 .NET 3.5 中似乎没有 OrderedDictionary(位于 System.Collections.Specialized 命名空间中)的通用实现。有没有我想念的? 我已经找到了提供该功
我有一个包含汇率值的 OrderedDictionary。每个条目都有一个键的日期(每个日期恰好是每年一个季度的开始),值是一个数字。日期按从旧到新的顺序插入。 { date(2017, 1,
在 .NET 3.5 中似乎没有 OrderedDictionary(位于 System.Collections.Specialized 命名空间中)的通用实现。有没有我想念的? 我已经找到了提供该功
前几天,我的一位同事在我们将项目升级到 .NET 4 时遇到了这个问题。 鉴于以下代码: var od = new System.Collections.Specialized.OrderedDic
我有一个从 this repository 中采用的通用 OrderedDictionary并且按预期工作正常。我想添加一个扩展方法来返回给定 TKey 的索引号。 Generic OrderedDi
我有两个键值对,现在我想用较小的值以串行方式填充较大的键值对。 OrderedDictionary pickersPool = new OrderedDictionary(); // Small
我宁愿不在有序字典中将两个单独的值创建到单独的条目中,但如果有一种方法可以完成我在这里尝试做的事情,那就太棒了。 public OrderedDictionary spellResults = new
当 OrderedDictionary、ListDictionary 和 HybridDictionary 这三种不同的字典都执行相似的功能时,它们需要什么? 它们都不是排序的,集合中的元素都可以通过
如何通过索引从 OrderedDictionary 中获取项目的键和值? 最佳答案 orderedDictionary.Cast().ElementAt(index); 关于c# - 如何通过索引从
我想给 OrderedDictionary ( https://github.com/lukaskubanek/OrderedDictionary ) 赋值,这样就可以了。 var orderedDi
如何从 OrderedDictionary 转换至 Dictionary以简洁但高效的方式? 情况: 我有一个我无法触及的库,它希望我通过 Dictionary .我想建立一个 OrderedDict
我有一个自定义的 GridView 控件(继承 system.web.ui.webcontrols.gridview),我想根据用户最近插入的值(inserted values不致力于数据源)。 在
我被指派按照词典编排的方式将字谜组合在一起。 下面是其中一个测试用例: 输入:吃茶 tan ate nat bat 输出: 吃喝茶 bat 自然光 但是,我不断收到这样的类型错误:TypeError:
我是一名优秀的程序员,十分优秀!