当前位置: 首页 > wzjs >正文

搜狗推广做网站要钱吗seo诊断书

搜狗推广做网站要钱吗,seo诊断书,网站设计与建设公司,公司网站介绍范文滚动hash 滚动哈希(rolling hash)也叫 Rabin-Karp 字符串哈希算法,它是将某个字符串看成某个进制下的整数,并将其对应的十进制整数作为hash值。 滚动hash算法的推导 假设有一个长度为n的数组a[0],a[1],a[2],…a[n-1]&#xff0…

滚动hash

滚动哈希(rolling hash)也叫 Rabin-Karp 字符串哈希算法,它是将某个字符串看成某个进制下的整数,并将其对应的十进制整数作为hash值。

滚动hash算法的推导

假设有一个长度为n的数组a[0],a[1],a[2],…a[n-1],数组中的最大值为ma, 我们选取进制k满足k>ma,将数组a看成是n位k进制整数,那么其对应的10进制整数为:

∑ i = 0 n − 1 a [ i ] ∗ k n − 1 − i \sum_{i=0}^{n-1} a[i] * k^{n-1-i} i=0n1a[i]kn1i

这样一来,在子数组长度固定的前提下,给定进制 k,子数组与其十进制值满足「一一对应」的关系,即不会有两个不同的子数组,它们的十进制值相同。因此滚动哈希得到的哈希值是可以表示原子数组的。

滚动哈希的一大优势在于,如果我们需要求出一个数组中长度为 len 的所有子数组的哈希值,需要的时间仅为线性,即如果我们已经计算出数组中以 j 开始的子数组的哈希值:

h a s h ( j ) = ∑ i = 0 l e n − 1 a [ j + i ] ∗ k l e n − 1 − i hash(j) = \sum_{i=0}^{len-1} a[j+i] * k^{len-1-i} hash(j)=i=0len1a[j+i]klen1i

那么要计算以 j+1 开始的子数组的哈希值,我们通过公式推导:

h a s h ( j + 1 ) = ∑ i = 0 l e n − 1 a [ j + 1 + i ] ∗ k l e n − 1 − i = ∑ i = 1 l e n a [ j + i ] ∗ k l e n − i = k ( ∑ i = 1 l e n a [ j + i ] ∗ k l e n − 1 − i ) = k ( h a s h ( j ) − a [ j ] ∗ k l e n − 1 + a [ j + l e n ] ∗ k − 1 ) = k ∗ h a s h ( j ) − a [ j ] ∗ k l e n + a [ j + l e n ] \begin{aligned} hash(j+1) &= \sum_{i=0}^{len-1} a[j+1+i] * k^{len-1-i} \\ &= \sum_{i=1}^{len} a[j+i]*k^{len-i} \\ &= k(\sum_{i=1}^{len} a[j+i]*k^{len-1-i}) \\ &= k(hash(j) - a[j]*k^{len-1} + a[j+len]*k^{-1}) \\ &= k*hash(j) - a[j]*k^{len} + a[j+len] \end{aligned} hash(j+1)=i=0len1a[j+1+i]klen1i=i=1lena[j+i]kleni=k(i=1lena[j+i]klen1i)=k(hash(j)a[j]klen1+a[j+len]k1)=khash(j)a[j]klen+a[j+len]

就可以在 ϕ ( 1 ) \phi(1) ϕ(1)的时间内得到该值。

利用滚动hash算法计算最长公共子路径的代码示例如下:

请添加图片描述

上述代码的执行效率较低,以下代码通过二分法优化,可以有效降低代码的时间复杂度:

def longest_common_subpath_2(n: int, paths: List[List[int]]) -> int:mod = (10 ** 9 + 7) * (10 ** 9 + 9)base = 10 ** 6 + 3# get min len of pathsmin_len = len(min(paths, key=lambda x: len(x)))def check(x: int) -> bool:k = pow(base, x, mod)hash_values = defaultdict(int)for path in paths:cnt = Counter()hash_value = 0for i in range(x):hash_value = (hash_value * base + path[i]) % modcnt[hash_value] += 1hash_values[hash_value] += 1for i in range(x, len(path)):hash_value = (hash_value * base + path[i] - path[i - x] * k) % modif hash_value not in cnt:cnt[hash_value] += 1hash_values[hash_value] += 1return max(hash_values.values(), default=0) == len(paths)l, r, ans = 1, min_len, 0while l <= r:mid = (l + r) >> 1if check(mid):ans = midl = mid + 1else:r = mid - 1return ans
http://www.dtcms.com/wzjs/171991.html

相关文章:

  • 做网站必须要dreamever百度联盟是什么
  • 烤肉自助餐网站建设推广资讯
  • 自己如何建设外贸网站建站快速排名新
  • 网络公司管理系统廊坊seo外包公司费用
  • 泰州哪里做网站百度游戏排行榜风云榜
  • 哈尔滨建站哪个好seo技术介绍
  • 第二季企业网站开发产品经理培训哪个机构好
  • 北京怀柔区建设委员会网站seo视频教学网站
  • 企业大型网站开发建站教程详解做一个网站需要多少钱
  • 访问一个网站的全过程公司培训课程有哪些
  • 站群系统软件公众号推广一个6元
  • 网站域名备案和icp备案一样么谷歌浏览器网页版进入
  • 建设食品商购网站杭州百度推广优化排名
  • 厦门网站建设代理搜狗seo查询
  • 自己学做网站需要学多久山东网站seo推广优化价格
  • 做电影网站程序好用双11销售数据
  • wordpress自适应方法信息如何优化上百度首页公司
  • 藁城网站建设哪家好网站项目开发流程
  • 网站引入视频播放鞋子软文推广300字
  • 全屏背景网站连云港百度推广总代理
  • 网站联系方式要素软文价格
  • php网站开发实例教程 源代码seo的优化策略有哪些
  • 做网站沈阳本地影视站seo教程
  • 盘锦做网站电话软广告经典例子
  • 淄博北京网站建设建立网站平台需要多少钱
  • 邯郸网站设计培训怎样创建网页
  • 如果做vr参观网站网站推广服务外包
  • redis 在网站开发中怎么用新闻平台发布
  • 个人网站设计图华为seo诊断及优化分析
  • 微信公众号采集插件wordpress冯宗耀seo教程