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

哪个视频网站做视频最赚钱百度推广关键词优化

哪个视频网站做视频最赚钱,百度推广关键词优化,成都知名网络营销公司,58同城找工作 招聘前言:处理字符串是蓝桥杯国赛经常会用到的,我们这里学习一下字符串哈希 下面是一个Python字符串哈希教程,内容涵盖了从基础概念到进阶应用,包括经典的滚动哈希(Rolling Hash),用于字符串匹配&am…

前言:处理字符串是蓝桥杯国赛经常会用到的,我们这里学习一下字符串哈希


下面是一个Python字符串哈希教程,内容涵盖了从基础概念到进阶应用,包括经典的滚动哈希(Rolling Hash),用于字符串匹配(如 Rabin-Karp 算法)和子串比较等常见场景。


📘 字符串哈希教程(Python 实现)

🔹 一、什么是字符串哈希?

字符串哈希是一种将一个字符串映射为一个整数的方法,常用于快速比较字符串是否相等。
如果两个字符串的哈希值相等,它们很可能是相等的(有哈希冲突的风险,但通常可以通过双哈希避免)。


🔹 二、基础哈希函数

我们使用如下公式将一个字符串 s 转换为哈希值(模拟多项式):

H ( s ) = s 0 ⋅ P 0 + s 1 ⋅ P 1 + s 2 ⋅ P 2 + … + s n − 1 ⋅ P n − 1 m o d M H(s) = s_0 \cdot P^0 + s_1 \cdot P^1 + s_2 \cdot P^2 + \ldots + s_{n-1} \cdot P^{n-1} \mod M H(s)=s0P0+s1P1+s2P2++sn1Pn1modM

  • P: 一个大于字母表大小的质数(如 31 或 131)
  • M: 一个大的模数(如 1 0 9 + 7 10^9 + 7 109+7
✅ 示例代码:
def string_hash(s, P=131, M=10**9 + 7):h = 0for ch in s:h = (h * P + ord(ch)) % Mreturn hprint(string_hash("hello"))
print(string_hash("hell"))

🔹 三、滚动哈希(Rolling Hash)

滚动哈希常用于子串比较,我们提前计算每个前缀的哈希值,使得任意子串的哈希值可以在 O(1) 时间获得。

✅ 构造哈希前缀数组和 P 的幂数组:
class RollingHash:def __init__(self, s, P=131, M=10**9 + 7):self.s = sself.P = Pself.M = Mn = len(s)self.hash = [0] * (n + 1)self.power = [1] * (n + 1)for i in range(n):self.hash[i + 1] = (self.hash[i] * P + ord(s[i])) % Mself.power[i + 1] = self.power[i] * P % M# 获取 s[l:r] 的哈希值(注意:左闭右开区间)def get_hash(self, l, r):return (self.hash[r] - self.hash[l] * self.power[r - l]) % self.M

这里有一个细节需要处理,就是我们的pow是我们的缩放比例

举个例子,s = “abc”
字符串的哈希值从头开始依次是
a
a * p + b
(a * p+b) * p + c

那么我们计算我们的bc的字符串哈希的值就需要我们用 (a * p+b) * p + c 减去 a * 缩放比例,这里的缩放比例为 p * p

✅ 使用示例:
rh = RollingHash("abracadabra")
print(rh.get_hash(0, 3))  # hash("abr")
print(rh.get_hash(7, 10)) # hash("abr")

当然不难,下面是一些循序渐进的实战题目,从入门到中等难度,帮助你巩固字符串哈希的概念和应用。


🧠 字符串哈希实战题目

🌱 入门题目

1. 比较两个子串是否相等(基础)

描述:给定一个字符串 s,和多个查询 (l1, r1, l2, r2),判断 s[l1:r1] == s[l2:r2] 吗?

输入

s = "abracadabra"
queries = [(0, 3, 7, 10), (0, 4, 4, 8)]

输出

True
False

提示:使用滚动哈希 + 子串哈希快速判断是否相等。


2. 找出字符串中所有长度为 k 的不同子串个数

描述:给定字符串 s 和整数 k,统计所有长度为 k唯一子串个数。

输入

s = "abcdabc"
k = 3

输出

5

子串:“abc”, “bcd”, “cda”, “dab”, “abc”(第二个 “abc” 忽略)


🌿 进阶题目

3. 最长公共子串(LCS)长度(字符串哈希 + 二分)

描述:给定两个字符串 s1s2,求它们的最长公共子串长度

思路提示:使用二分长度 + 哈希集合判断是否存在公共子串。


4. 是否存在重复的长度为 k 的子串(经典)

描述:给定字符串 s 和整数 k,判断是否存在两个不同位置的长度为 k 的重复子串。

例子

s = "banana", k = 2
输出: True ("an" 出现了两次)

5. 字符串循环等价判定(哈希版)

描述:给定两个字符串 s1s2,判断 s2 是否为 s1 的循环变换(例如 "abc" 的变换包括 "bca""cab")。

技巧提示:判断 s2 是否为 s1 + s1 的子串。


🚀 挑战题目

6. 最长回文子串长度(哈希 + 二分)

描述:求一个字符串中最长回文子串的长度(可以用 Manacher 或哈希 + 二分实现)。


http://www.dtcms.com/wzjs/781633.html

相关文章:

  • 网站制作代码大全家居商城网站模板
  • 网站总是打不开做iframe跳转怎么自适应网站
  • 广西冶金建设公司网站个性婚纱摄影
  • 模板式自助建站dede导入wordpress
  • 如何做美发店网站公众号推广平台
  • 中华住房和城乡建设厅网站天津网站优化怎么样
  • 山西省建设局官方网站怎么自建网站
  • 做软件需要网站个人网站建设制作
  • 运河建设集团网站中信建设有限责任公司总监
  • 网站怎么注册一家专门做打折的网站
  • 做视频类型的网站常州市城乡建设局网站
  • 网站开发对企业的关键wordpress全站加密
  • 凡科网做网站教程怎么在网上卖东西给外国人
  • 百度站长工具网站规避电子政务门户网站建设的教训
  • 好看的网站首页欣赏seo网站关键词
  • 网站制作哪个好薇wordpress无法连接数据库连接
  • discuz做门户网站郑州网页制作设计
  • 自己怎么做简单的网站wordpress 帮助模板
  • 网站仿制公司建设银行手机银行app类型
  • 建设银行行号网站查询是什么意思用dw做音乐网站模板
  • 万域网站建设东莞网站建设企慕
  • 网站的设计思路可以做视频片头的网站
  • 网站流量数据在线设计商标logo
  • 怎么做网站美工如何做网站地图
  • 视频网站如何推广微科技h5制作网站
  • 网站建设优化服务效果兰州设计公司有哪些
  • 网站设计制作的特点有哪些产品展示网站源码php
  • 自己制作网站需要什么外贸公司手机网站
  • 建设农村信息网站佛山外贸网站建设报价
  • 白银网站模板邵阳小学网站建设