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

网页设计好看的网站梅州网站制作

网页设计好看的网站,梅州网站制作,做家教用什么网站,wordpress飘花特效文章目录 一、题目二、C# 题解 一、题目 字符串轮转。给定两个字符串 s1 和 s2,请编写代码检查 s2 是否为 s1 旋转而成(比如,waterbottle 是 erbottlewat 旋转后的字符串)。 点击此处跳转题目。 示例1: 输入:s1 “wa…

文章目录

  • 一、题目
  • 二、C# 题解

一、题目

  字符串轮转。给定两个字符串 s1s2,请编写代码检查 s2 是否为 s1 旋转而成(比如,waterbottleerbottlewat 旋转后的字符串)。

  点击此处跳转题目。

示例1:

输入:s1 = “waterbottle”, s2 = “erbottlewat”
输出:True

示例2:

输入:s1 = “aa”, s2 = “aba”
输出:False

提示:

  • 字符串长度在[0, 100000]范围内。

说明:

  • 你能只调用一次检查子串的方法吗?

二、C# 题解

  可以将题目理解为从字符串内部切一刀换序重组,判断是否能变为原字符串。但按照该思路写复杂度为 O ( n 2 ) O(n^2) O(n2),不是很理想,因此还是从字符入手。

  使用双指针 i,j 从左向右分别指向 s1,s2i 的任务是遍历 s1,查找 s2s1 中的前缀;j 的任务是标识 s2 中前缀的位置,即 s2[0]~s2[j - 1]s2s1 相同的部分。

  以 s1:bunana, s2:nabuna 为例,可以看出,s1:buna | nas2:na | bunas1 的后缀和 s2 的前缀想同,均为 na,算法的具体流程如下:

b u n a n a ( s 1 ) i : ↑ n a b u n a ( s 2 ) j : ↑ ⇓ b u n a n a ( s 1 ) i : ↑ n a b u n a ( s 2 ) j : ↑ ⇓ b u n a n a ( s 1 ) i : ↑ n a b u n a ( s 2 ) j : ↑ ⇓ b u n a n a ( s 1 ) i : ↑ n a b u n a ( s 2 ) j : ↑ ⇓ b u n a n a ( s 1 ) i : ↑ n a b u n a ( s 2 ) j : ↑ ⇓ b u n a n a ( s 1 ) i : ↑ n a b u n a ( s 2 ) j : ↑ ⇓ b u n a n a ( s 1 ) i : ↑ n a b u n a ( s 2 ) j : ↑ \begin{array}{l} & b & u & n & a & n & a & (s1)\\ i:& \uparrow & & & & \\ & n & a & b & u & n & a & (s2)\\ j:& \uparrow & & & & \end{array}\\ ~\\\ \Downarrow\\ ~\\\ \begin{array}{l} & b & u & n & a & n & a & (s1)\\ i:& & \uparrow & & & \\ & n & a & b & u & n & a & (s2)\\ j:& \uparrow & & & & \end{array}\\ ~\\\ \Downarrow\\ ~\\\ \begin{array}{l} & b & u & n & a & n & a & (s1)\\ i:& & & \uparrow & & \\ & n & a & b & u & n & a & (s2)\\ j:& \uparrow & & & & \end{array}\\ ~\\\ \Downarrow\\ ~\\\ \begin{array}{l} & b & u & n & a & n & a & (s1)\\ i:& & & & \uparrow & \\ & n & a & b & u & n & a & (s2)\\ j:& & \uparrow & & & \end{array}\\ ~\\\ \Downarrow\\ ~\\\ \begin{array}{l} & b & u & n & a & n & a & (s1)\\ i:& & & & & \uparrow \\ & n & a & b & u & n & a & (s2)\\ j:& \uparrow & & & & \end{array}\\ ~\\\ \Downarrow\\ ~\\\ \begin{array}{l} & b & u & n & a & n & a & (s1)\\ i:& & & & & & \uparrow \\ & n & a & b & u & n & a & (s2)\\ j:& & \uparrow & & & \end{array}\\ ~\\\ \Downarrow\\ ~\\\ \begin{array}{l} & b & u & n & a & n & a & (s1)\\ i:& & & & & & & \uparrow \\ & n & a & b & u & n & a & (s2)\\ j:& & & \uparrow & & \end{array}\\ i:j:bnuanbaunnaa(s1)(s2)    i:j:bnuanbaunnaa(s1)(s2)    i:j:bnuanbaunnaa(s1)(s2)    i:j:bnuanbaunnaa(s1)(s2)    i:j:bnuanbaunnaa(s1)(s2)    i:j:bnuanbaunnaa(s1)(s2)    i:j:bnuanbaunnaa(s1)(s2)

  最终,i 指向 s1 的末尾,j 指向 s2 前缀的后一字符,即 s2 后缀的起始位置。

public class Solution {public bool IsFlipedString(string s1, string s2) {int l1 = s1.Length, l2 = s2.Length;if (l1 != l2) return false;  // 长度不相等直接否掉int i = 0, j = 0;            // 双指针,i 指 s1,j 指 s2while (i < l1) {             // 遍历 s1,寻找 s2 的前缀if (s1[i] == s2[j]) j++; // 如果字符相同,则 j 后移else {                   // 字符不同,则 i、j 回退i -= j;j = 0;}i++;                     // i 始终前进}i = 0;while (j < l2) {             // 检查 s2 后缀是否为 s1 前缀if (s1[i++] != s2[j++]) return false;}return true;}
}
  • 时间复杂度:一般情况下为 O ( n ) O(n) O(n),但波动较大。最坏情况为 O ( n 2 ) O(n^2) O(n2),即字符串包含大部分重复字符。可以使用 KMP 算法优化,懒了没必要。
  • 空间复杂度: O ( 1 ) O(1) O(1)
http://www.yayakq.cn/news/917579/

相关文章:

  • php 网站cookie沈阳网络推广培训
  • 网站是先解析后备案吗网站建设需要哪些流程
  • ps制作网站模板天津招聘网人才招聘官网
  • centos建设网站保山做网站
  • 网站建设新闻发布注意创网址
  • 网站后台和前台开设赌场罪 网站开发
  • 公司网站制作应该注意些什么手机网站 link和visited设置同一种颜色失效
  • 朝阳改版网站网页文档
  • 南京服务好建设网站哪家好企业网站的建立和推广
  • 招聘网站是做什麼的网站制作 价格
  • seo优化与sem推广有什么关系为什么seo工资不高
  • 做网站属于什么学科中小企业公司
  • 网站平台如何推广安阳市网站建设
  • 安丘市住房与城市建设路网站新房
  • 建设网站公司怎么样网络营销的职业
  • 潍坊建网站郑州网站推
  • 网站怎么做友情连接宜兴市城乡建设局网站
  • 做网站程序的都不关注seo设计图纸用什么软件
  • 网站seo报告想接网站自己做
  • 做gif动态图网站网页制作流程及详细步骤
  • 网站没有内容 能做优化吗推荐十个网站
  • 有网址 有空间怎么做网站专业网站推广的公司哪家好
  • firework做网站教程网站轮播广告动画怎么做
  • 信息中心完成网站建设建站怎么赚钱
  • 河北省建设厅网站老版网站维护合同模板
  • 成都网站建设网站制作公司长沙招聘网站制作
  • 网站建设建设公司资质要求东莞设计兼职网站建设
  • 网站建设基本问题有服务器和网站代码了 怎么建站
  • 合肥 网站运营职称论文写作网站
  • 销售新网站推广策略做购物网站需要学数据库吗