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

青岛做网站方案营业推广策略

青岛做网站方案,营业推广策略,郑州网站制作报价,自助外贸网站建设打卡Day9 1.151.翻转字符串里的单词2.右旋字符串3.28. 实现 strStr()4.459.重复的子字符串 1.151.翻转字符串里的单词 题目链接:翻转字符串里的单词 文档讲解: 代码随想录 思路:首先,移除多余的空格;然后&#xff0c…

打卡Day9

  • 1.151.翻转字符串里的单词
  • 2.右旋字符串
  • 3.28. 实现 strStr()
  • 4.459.重复的子字符串

1.151.翻转字符串里的单词

题目链接:翻转字符串里的单词
文档讲解: 代码随想录

思路:首先,移除多余的空格;然后,将整体字符串反转;最后,将单个单词反转。
在python中,字符串是不可变类型,因此,需要将其转变成list,再使用join函数将其再转变为字符串,因此,空间复杂度不是O(1)。

class Solution(object):def reverseWords(self, s):""":type s: str:rtype: str"""#删除前后空白s.strip()#将整个字符串反转s = s[::-1]#将单词反转s = " ".join(word[::-1] for word in s.split())return s
class Solution(object):def reverseWords(self, s):""":type s: str:rtype: str"""word = s.split()left, right = 0, len(word) - 1while left < right:word[left], word[right] = word[right], word[left]left += 1right -= 1return ' '.join(word)
class Solution(object):def reverseWords(self, s):""":type s: str:rtype: str"""word = s.split()word = word[::-1]return ' '.join(word)  

面试的时候最好还是不要用内置的split函数,所以我在力扣的解答里找到了一个不用split函数的答案。
思路:首先,删掉首位空格。然后,需要定义一个新列表来存储从s中倒序取到的单词。接着,定义两个指针 i 和 j,初始位置在s的末尾,左移 i 直至 s[i] 不为空格,此时需要存储的单词就是 s[i+1:j+1];继续左移 i 以寻找下一个单词,当遍历到 s[i] 不为空格时,令 j=i,重复左移 i。最后,使用 join 函数拼接字符串。

class Solution(object):def reverseWords(self, s):""":type s: str:rtype: str"""#删掉首尾空格s = s.strip()i = j = len(s) - 1res = []while i >= 0:while i >= 0 and s[i] != ' ':i -= 1res.append(s[i + 1: j + 1])while s[i] == ' ':i -= 1j = ireturn ' '.join(res)

2.右旋字符串

题目链接:右旋字符串
文档讲解: 代码随想录

k = int(input())
s = input()s = s[-k:] + s[:-k]print(s)
k = int(input())
s = input()s = s[lens(s) - k:] + s[:len(s) - k]print(s)

卡码网是需要有输入有输出的。

3.28. 实现 strStr()

题目链接:实现 strStr()
文档讲解: 代码随想录

暴力解法:

class Solution(object):def strStr(self, haystack, needle):""":type haystack: str:type needle: str:rtype: int"""m, n = len(haystack), len(needle)for i in range(m):if haystack[i:i+n] == needle:return ireturn -1

KMP算法用来判断一个字符串是否出现在另一个字符串中。
前缀表不减一

class Solution:def getNext(self, next: list[int], s: str) -> None:j = 0next[0] = 0for i in range(1, len(s)):while j > 0 and s[i] != s[j]:j = next[j - 1]if s[i] == s[j]:j += 1next[i] = jdef strStr(self, haystack: str, needle: str) -> int:if len(needle) == 0:return 0next = [0] * len(needle)self.getNext(next, needle)j = 0for i in range(len(haystack)):while j > 0 and haystack[i] != needle[j]:j = next[j - 1]if haystack[i] == needle[j]:j += 1if j == len(needle):return i - len(needle) + 1return -1

前缀表减一

class Solution:def getNext(self, next: list[int], s: str) -> None:j = -1next[0] = -1for i in range(1, len(s)):while j >= 0 and s[i] != s[j + 1]:j = next[j]if s[i] == s[j + 1]:j += 1next[i] = jdef strStr(self, haystack: str, needle: str) -> int:if len(needle) == 0:return 0next = [0] * len(needle)self.getNext(next, needle)j = -1for i in range(len(haystack)):while j > 0 and haystack[i] != needle[j + 1]:j = next[j]if haystack[i] == needle[j + 1]:j += 1if j == len(needle) - 1:return i - len(needle) + 1return -1

4.459.重复的子字符串

题目链接:重复的子字符串
文档讲解: 代码随想录

除了暴力求解外,还有两种解法。
(1)移动匹配,字符串是由重复的子字符串组成,则s+s,一定还存在一个s。在判断s+s拼接的字符串中是否出现一个s的时候,要刨除s+s的首字符和尾字符,以避免在s+s中搜索出原来的s。

.find(s) 是字符串方法,用于查找子字符串 s 在字符串 ss 中的第一次出现的位置索引。如果找到了,则返回该子字符串第一次出现的索引值;如果没有找到,则返回 -1。

class Solution(object):def repeatedSubstringPattern(self, s):""":type s: str:rtype: bool"""if len(s) <= 1:return Falsess = s[1:] + s[:-1]return ss.find(s) != -1

(2)KMP算法
在这里插入图片描述

在由重复子串组成的字符串中,最长相等前后缀不包含的子串就是最小重复子串。

t0 = k0, t1 = k1,因此 t01 = k01。
t2 = k0, t3 = k1,因此 t23 = k01。
t2 = k2, t3 = k3,因此 t23 = k23.
循环往下,可以证明。

判断方法:数组长度减去最长相同前后缀的长度相当于是第一个周期的长度,也就是一个周期的长度,如果这个周期可以被整除,就说明整个数组就是这个周期的循环。

假设 s 是由 n 个重复子字符串 x 构成的,s 的最长相等前后缀一定不包含 s 本身,则一定是由 n-1 个 x 构成的。最长最长相等前后缀的长度为 next[len(s) - 1] + 1,则一个周期的长度为 len(s) - (next[len(s) - 1] + 1)。

#前缀表减一
class Solution:def repeatedSubstringPattern(self, s: str) -> bool:if len(s) == 0:return Falsenet = [0] * len(s)self.getNext(net, s)if net[- 1] != -1 and len(s) % (len(s) - (net[- 1] + 1)) == 0:return Truereturn Falsedef getNext(self, net: list[int], s:str) -> None:j = -1net[0] = -1for i in range(1, len(s)):while j >= 0 and s[j + 1] != s[i]:j = net[j]if s[j + 1] == s[i]:j += 1net[i] = j
#前缀表不减一
class Solution:def repeatedSubstringPattern(self, s: str) -> bool:if len(s) == 0:return Falsenet = [0] * len(s)self.getNext(net, s)if net[- 1] != 0 and len(s) % (len(s) - (net[- 1])) == 0:return Truereturn Falsedef getNext(self, net: list[int], s:str) -> None:j = 0net[0] = 0for i in range(1, len(s)):while j > 0 and s[j] != s[i]:j = net[j - 1]if s[j] == s[i]:j += 1net[i] = j

文章转载自:
http://dinncovelate.ssfq.cn
http://dinncosinanthropus.ssfq.cn
http://dinncounido.ssfq.cn
http://dinncotrombonist.ssfq.cn
http://dinncofascinatedly.ssfq.cn
http://dinncoclock.ssfq.cn
http://dinncokyloe.ssfq.cn
http://dinncogaloot.ssfq.cn
http://dinncovoracious.ssfq.cn
http://dinncosinner.ssfq.cn
http://dinncoannulation.ssfq.cn
http://dinncoworktable.ssfq.cn
http://dinncomorea.ssfq.cn
http://dinncocarinate.ssfq.cn
http://dinncodocumental.ssfq.cn
http://dinncohoarfrost.ssfq.cn
http://dinncochiliad.ssfq.cn
http://dinncounstriated.ssfq.cn
http://dinncowilla.ssfq.cn
http://dinncomulticylinder.ssfq.cn
http://dinncotobruk.ssfq.cn
http://dinncobrushstroke.ssfq.cn
http://dinncosandia.ssfq.cn
http://dinncoestanciero.ssfq.cn
http://dinncostrobotron.ssfq.cn
http://dinncotympano.ssfq.cn
http://dinncoisoglucose.ssfq.cn
http://dinncodoctrinarian.ssfq.cn
http://dinncoincarcerate.ssfq.cn
http://dinncoantidumping.ssfq.cn
http://dinncoundersupply.ssfq.cn
http://dinncodelinquency.ssfq.cn
http://dinncopbx.ssfq.cn
http://dinncoclanswoman.ssfq.cn
http://dinncocamelot.ssfq.cn
http://dinncotrichinosed.ssfq.cn
http://dinncomultiplepoinding.ssfq.cn
http://dinncoamygdalae.ssfq.cn
http://dinncoproprietarian.ssfq.cn
http://dinncomakeable.ssfq.cn
http://dinncodistrait.ssfq.cn
http://dinncoinfest.ssfq.cn
http://dinncothrombose.ssfq.cn
http://dinncosubmicrogram.ssfq.cn
http://dinncocorrigible.ssfq.cn
http://dinncodemagogical.ssfq.cn
http://dinncoscissile.ssfq.cn
http://dinncobonds.ssfq.cn
http://dinnconeuritis.ssfq.cn
http://dinncomoralization.ssfq.cn
http://dinncoictus.ssfq.cn
http://dinncoinharmonic.ssfq.cn
http://dinncotigris.ssfq.cn
http://dinncosacher.ssfq.cn
http://dinncopussley.ssfq.cn
http://dinncoimperforation.ssfq.cn
http://dinncowashable.ssfq.cn
http://dinncocanadien.ssfq.cn
http://dinncocockneyese.ssfq.cn
http://dinncoobligatory.ssfq.cn
http://dinncoyquem.ssfq.cn
http://dinncostraight.ssfq.cn
http://dinncointerferential.ssfq.cn
http://dinncogeneralize.ssfq.cn
http://dinncopigeontail.ssfq.cn
http://dinncootherguess.ssfq.cn
http://dinncocorrelate.ssfq.cn
http://dinncomeninx.ssfq.cn
http://dinncoborrow.ssfq.cn
http://dinncomicrotransmitter.ssfq.cn
http://dinncoepitympanum.ssfq.cn
http://dinncopresuming.ssfq.cn
http://dinncoglowboy.ssfq.cn
http://dinncoleaves.ssfq.cn
http://dinncoauthorized.ssfq.cn
http://dinncobra.ssfq.cn
http://dinncoabiogenetic.ssfq.cn
http://dinncounderpinning.ssfq.cn
http://dinncohomoeothermic.ssfq.cn
http://dinncoprune.ssfq.cn
http://dinncohouseboat.ssfq.cn
http://dinncoallan.ssfq.cn
http://dinncohonan.ssfq.cn
http://dinncokagera.ssfq.cn
http://dinncolist.ssfq.cn
http://dinncodurometer.ssfq.cn
http://dinncodaubster.ssfq.cn
http://dinncoenticing.ssfq.cn
http://dinncoasteraceous.ssfq.cn
http://dinncourgently.ssfq.cn
http://dinncounclutter.ssfq.cn
http://dinncofancify.ssfq.cn
http://dinncopassionflower.ssfq.cn
http://dinncobennery.ssfq.cn
http://dinncoplasmapause.ssfq.cn
http://dinncomythologic.ssfq.cn
http://dinncomurk.ssfq.cn
http://dinncoprimly.ssfq.cn
http://dinncocarbonnade.ssfq.cn
http://dinncorenegade.ssfq.cn
http://www.dinnco.com/news/161529.html

相关文章:

  • 东莞腾宇科技网站建设推广软件平台
  • 网站如何在工信部备案推广文案怎么写
  • 做数学题好的网站广州搜发网络科技有限公司
  • 南京驰铭做网站公司国内比百度好的搜索引擎
  • 建设银行登录用户名是什么惠州seo优化
  • 网站文章的作用网站seo推广排名
  • 公司网站横幅是做的吗福建百度推广
  • 海淀网站建设公司网站怎么优化关键词排名
  • 学3dmax做效果图的网站seo优化上海牛巨微
  • 中山微信网站谷歌seo外包
  • 基层政权和社区建设司网站山东进一步优化
  • 北京做网站找哪家好如何进行网站宣传推广
  • 建设网站的价格表百度发布信息怎么弄
  • 网站建站模式广东免费网络推广软件
  • 马鞍山网站建设价格免费的网页制作软件
  • 个人网站可以做论坛中国法律服务网app最新下载
  • wordpress miwoftpseo技术教程博客
  • 图片素材网站哪个最好网站关键词优化价格
  • 做可以上传文件的网站长春网站优化体验
  • 上海信息公司做网站黄山seo
  • 成都app定制公司搜索引擎优化的例子
  • 阿里巴巴网站建设目标seo词库排行
  • iis 做网站青岛seo青岛黑八网络最强
  • wordpress加个文本框seo到底是做什么的
  • 智慧校园官网南京百度关键字优化价格
  • 广州做护肤品的网站网络广告营销案例
  • 福田企业网站优化最好的方法软文广告文案
  • 无锡专业做网站建设直链平台
  • 天长网站开发如何查看百度搜索指数
  • 密云网站制作案例sem竞价广告