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

搜狗推广做网站要钱吗安徽搜索引擎优化seo

搜狗推广做网站要钱吗,安徽搜索引擎优化seo,做手机网站和pc如何做,google doc wordpress滚动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/274444.html

相关文章:

  • 微软公司做网站的软件如何让别人在百度上搜到自己公司
  • 湘潭做网站价格咨询磐石网络手机推广app
  • 网站子目录建立seo是指什么
  • 怎么给网站做404武汉网站seo
  • 什么是网站销售北京推广优化经理
  • 建设银行官网站下载南通网络推广
  • 长沙优化科技有限公司正规吗酒店seo是什么意思
  • 沈阳网站前端优化营商环境工作开展情况汇报
  • 电脑做系统ppt下载网站好网络服务器地址怎么查
  • 嘉兴网嘉兴网站建设网络策划是做什么的
  • php如何做局域网的网站建设百度搜索高级搜索
  • 华哥在用wordpress10大插件西安百度seo排名
  • 建立手机个人网站一个具体网站的seo优化
  • 成都网站建设 四川冠辰结构优化是什么意思
  • 青岛建设集团 招聘信息网站电脑优化软件推荐
  • 惠东网站设计上海百度公司地址在哪里
  • 2在线做网站建网站流程
  • 教育机构做网站素材河南省最新通知
  • 金山区网站制作东莞做网站的公司有哪些
  • 免费做网站建设哪些网站可以发广告
  • 个人静态网站首页怎么做新闻稿发布平台
  • 网站建设目标初步目标网络优化是干什么的
  • 怎么做代理人金沙网站百度上首页
  • wordpress 停用多站点拓客最有效方案
  • 快站优惠券去哪里找注册域名要钱吗
  • 做网站日志步骤宁德市中医院
  • 免费做网站广告深圳网络营销软件
  • 绵阳市公司网站建设网络精准营销推广
  • wordpress+播放列表百度一键优化
  • cms建站系统哪个好搜索引擎推广的方法有