RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1183241
Accepted
Владислав Харламов
Владислав Харламов
Asked:2020-09-28 01:29:37 +0000 UTC2020-09-28 01:29:37 +0000 UTC 2020-09-28 01:29:37 +0000 UTC

滑动窗口计数

  • 772

假设我有data一个迭代器,我想为它计算k一个可迭代对象的连续元素,(elem_1, elem_2, ..., elem_k)并为每个这样的“窗口”在字典中存储它遇到的次数,最有效的方法是什么?对于O(n).

示例:"abcabc", k = 3,我们得到:
(a,b,c), (b,c,a), (c,a,b), (a,b,c)因此,应该会出现以下字典:
(a,b,c) : 2, (b,c,a) : 1, (c,a,b) : 1。

python
  • 4 4 个回答
  • 10 Views

4 个回答

  • Voted
  1. Best Answer
    vp_arth
    2020-09-28T02:11:58Z2020-09-28T02:11:58Z
    s = 'abcabc'
    stat = dict()
    s = tuple(list(s))
    
    k = 3
    for p in (s[i:i+k] for i in range(0, len(s)-k+1)):
        stat[p] = stat.get(p, 0) + 1
    

    迭代器的实现,无需初步减法到内存中list(data)(也是 O(kN))。

    def impl_it(data, k):
      stat = dict()
      win = []
      for _ in range(k):
        win.append(next(data))
    
      key = tuple(win)
      stat[key] = stat.get(key, 0) + 1
      for el in data:
        win = win[1:]
        win.append(el)
    
        key = tuple(win) # O(k)
        stat[key] = stat.get(key, 0) + 1
      return stat
    

    由于需要建key/计算hash,所以循环内部的O(k)在所难免,所以用一些deque替换window来优化win[1:]情况并不会改善。

    • 4
  2. RomanR
    2020-09-28T02:02:52Z2020-09-28T02:02:52Z

    我不知道需要什么?

    st = "abcabc"
    k = 3
    def funk(st, k):
        myD = dict()
        for i in range(len(st) - k + 1):
            myD[tuple(st[i:i+3])] = myD.get(tuple(st[i:i+3]), 0) + 1 # получаем значание из словаря, если ключа нет, то 0 + 1 = 1, если есть, то + 1
        return myD
    
    print(funk(st, k))
    
    • 1
  3. S. Nick
    2020-09-28T02:05:52Z2020-09-28T02:05:52Z

    作为一种选择:

    a, b, c = 1, 2, 3
    data = (a,b,c), (b,c,a), (c,a,b), (a,b,c)
    _dict = {}
    
    for i in data:
        _dict[i] = _dict.get(i, 0)
        _dict[i] += 1
        
    print(_dict)
    # {(1, 2, 3): 2, (2, 3, 1): 1, (3, 1, 2): 1}
    
    • 1
  4. dIm0n
    2020-09-28T04:24:34Z2020-09-28T04:24:34Z

    像这样:

    import collections
    
    a = "abcabc"
    k = 3
    
    print(dict(collections.Counter(zip(*[a[i:] for i in range(k)]))))
    

    不切片选项:

    import collections, itertools
    
    a = "abcabc"
    k = 3
    
    print(dict(collections.Counter(zip(*[itertools.islice(a, i, len(a)) for i in range(k)]))))
    
    • 1

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    如何从列表中打印最大元素(str 类型)的长度?

    • 2 个回答
  • Marko Smith

    如何在 PyQT5 中清除 QFrame 的内容

    • 1 个回答
  • Marko Smith

    如何将具有特定字符的字符串拆分为两个不同的列表?

    • 2 个回答
  • Marko Smith

    导航栏活动元素

    • 1 个回答
  • Marko Smith

    是否可以将文本放入数组中?[关闭]

    • 1 个回答
  • Marko Smith

    如何一次用多个分隔符拆分字符串?

    • 1 个回答
  • Marko Smith

    如何通过 ClassPath 创建 InputStream?

    • 2 个回答
  • Marko Smith

    在一个查询中连接多个表

    • 1 个回答
  • Marko Smith

    对列表列表中的所有值求和

    • 3 个回答
  • Marko Smith

    如何对齐 string.Format 中的列?

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5