zoukankan      html  css  js  c++  java
  • 【CodeForces】914 F. Substrings in a String bitset

    【题目】F. Substrings in a String

    【题意】给定小写字母字符串s,支持两种操作:1.修改某个位置的字符,2.给定字符串y,查询区间[l,r]内出现y多少次。|s|,Σ|y|<=10^5,time=6s。

    【算法】Bitset

    【题解】假设S的长度为n,那么对每个字符建一个长度为n的bitset,1表示该位置为该字符,修改时直接修改。

    查询的时候将字符串y所有的字符的bitset,按顺序错位and,这样最后得到1表示y为子串,count一下即可。

    复杂度O(n^2/32),极限复杂度约3*10^8,可以在time=6s内通过。

    代码链接

  • 相关阅读:
    第八周作业。
    作业。
    第七周作业。
    作业。
    Android简易计算器
    Android第四周
    java6.12
    java5.29
    java5.28
    java5.22
  • 原文地址:https://www.cnblogs.com/onioncyc/p/8879656.html
Copyright © 2011-2022 走看看