旋转字符串

https://leetcode.cn/problems/rotate-string/

给定两个字符串, s 和 goal。如果在若干次旋转操作之后,s 能变成 goal ,那么返回 true 。

s 的 旋转操作 就是将 s 最左边的字符移动到最右边。

例如, 若 s = 'abcde',在旋转一次之后结果就是'bcdea' 。

示例 1:

输入: s = "abcde", goal = "cdeab"

输出: true

示例 2:

输入: s = "abcde", goal = "abced"

输出: false

提示:

1 <= s.length, goal.length <= 100

s 和 goal 由小写英文字母组成

思路

与重复子串一样有两种思路:

1、直接将字符串s和goal相加,然后再相加后的字符串中查找s或者goal,找到就可以返回true

2、使用KMP算法

先求出s的next数组,然后还是将字符串s和goal相加,得到新字符串

goal 字符串复制一份连接到自身末尾,得到新的字符串 s2 的目的是为了模拟旋转操作之后的字符串。

假设原始字符串是 s,通过左旋若干次后得到的新字符串是 s'。如果我们将 ss' 进行比较,就会发现它们实际上是相同的字符串,只是从不同位置开始截取的。而这个位置的关系可以通过将 goal 复制一份连接到自身末尾来体现。

举个例子:假设 s = "abcde",将 s 左移两位得到的新字符串是 s' = "cdeab"。那么将 goal 复制一份连接到自身末尾,得到的字符串是 goal + goal = "cdeababcde"。我们可以发现,在 goal + goal 中,第一个 goals' 是对应的,因为它们都是从 c 开始的;第二个 goal 对应的就是 s,因为它们都是从 a 开始的。

使用KMP算法在新字符串中查找s

为了这点醋包了这碗面

代码

字符串相加使用find
//与重复子字符串的简单版本思路类似
class Solution {
public:
bool rotateString(string s, string goal) {
return s.size() == goal.size() && (s + s).find(goal) != string::npos;
}
};
脱裤子放屁法(KMP)
class Solution {
private:
void getNext(int* next, string& s){
int j = -1;
next[0] = j;
for(int i = 1 ;i < s.size(); ++i){
while(j >= 0 && s[i] != s[j + 1]) j = next[j]; if(s[i] == s[j + 1]) j++;
next[i] = j;
}
}
public:
bool rotateString(string s, string goal) {
//判断一下,如果两个字符串长度不等直接false,如果给的字符串是空,那怎么转都可以得到本身,返回true
//s为空goal不空的情况已经包含第一个判断中
if(s.size() != goal.size()) return false;
if(s.empty()) return true; // 将goal字符串复制一份连接到自身末尾,得到新的字符串s2
string s2 = goal + goal; //string s2 = s + goal;也行
int j = -1;
int next[s.size()];
getNext(next, s); for(int i = 0; i < s2.size(); ++i){//在s2中查找s
while(j >= 0 && s2[i] != s[j + 1]){
j = next[j];
} if(s2[i] == s[j + 1]){
j++;
} if(j == s.size() - 1) return true;//遍历完s后结束
}
return false;
}
};

字符串轮转

https://leetcode.cn/problems/string-rotation-lcci/

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

示例1:

输入:s1 = "waterbottle", s2 = "erbottlewat"

输出:True

示例2:

输入:s1 = "aa", s2 = "aba"

输出:False

提示:

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

说明:

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

思路

和旋转字符串一样,直接给代码

代码

字符串相加使用find
//与重复子字符串的简单版本思路类似
class Solution {
public:
bool isFlipedString(string s1, string s2) {
return s1.size() == s2.size() && (s2 + s2).find(s1) != string::npos;
}
};
KMP
//kmp版本
class Solution {
private:
void getNext(int* next, string& s){
int j = -1;
next[0] = j; for(int i = 1; i < s.size(); ++i){
while(j >= 0 && s[j + 1] != s[i]){
j = next[j];
} if(s[j + 1] == s[i]) j++;
next[i] = j;
} }
public:
bool isFlipedString(string s1, string s2) {
if(s1.size() != s2.size()) return false;
if(s1.empty()) return true; int j = -1;
int next[s1.size()];
string ss2 = s2 + s2;
getNext(next, s1); for(int i = 0; i < ss2.size(); ++i){
while(j >= 0 && ss2[i] != s1[j + 1]) j = next[j]; if(ss2[i] == s1[j + 1]) j++; if(j == s1.size() - 1) return true;
}
return false;
}
};

【LeetCode字符串#extra】KMP巩固练习:旋转字符串、字符串轮转的更多相关文章

  1. leetcode——Reverse Words in a String 旋转字符串中单词顺序(AC)

    题目例如以下: Given an input string, reverse the string word by word. For example, Given s = "the sky ...

  2. 字符串匹配算法——KMP算法学习

    KMP算法是用来解决字符串的匹配问题的,即在字符串S中寻找字符串P.形式定义:假设存在长度为n的字符数组S[0...n-1],长度为m的字符数组P[0...m-1],是否存在i,使得SiSi+1... ...

  3. c算法:字符串查找-KMP算法

    /* *用KMP算法实现字符串匹配搜索方法 *该程序实现的功能是搜索本目录下的所有文件的内容是否与给定的 *字符串匹配,如果匹配,则输出文件名:包含该字符串的行 *待搜索的目标串搜索指针移动位数 = ...

  4. 【字符串】KMP字符串匹配

    百度百科 Definition \(KMP\)算法是一个字符串匹配算法.他接收两个字符串\(A,B\),返回\(B\)在\(A\)中出现的所有位置. 以下称需要被匹配的串\(A\)为主串,可能在主串中 ...

  5. Leetcode 91. Decode Ways 解码方法(动态规划,字符串处理)

    Leetcode 91. Decode Ways 解码方法(动态规划,字符串处理) 题目描述 一条报文包含字母A-Z,使用下面的字母-数字映射进行解码 'A' -> 1 'B' -> 2 ...

  6. 【字符串】KMP

    Algorithm Task 给定一个文本串 \(S\) 和一个模式串 \(T\),求 \(T\) 在 \(S\) 中出现的所有位置. Limitations 要求时空复杂度均为线性. Solutio ...

  7. 算法数据结构 | 只要30行代码,实现快速匹配字符串的KMP算法

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是算法数据结构专题的第29篇文章,我们来聊一个新的字符串匹配算法--KMP. KMP这个名字不是视频播放器,更不是看毛片,它其实是由Kn ...

  8. [LeetCode]1249. 移除无效的括号(字符串,栈)

    题目 给你一个由 '('.')' 和小写字母组成的字符串 s. 你需要从字符串中删除最少数目的 '(' 或者 ')' (可以删除任意位置的括号),使得剩下的「括号字符串」有效. 请返回任意一个合法字符 ...

  9. HDOJ-1358(字符串压缩+KMP)

    Period HDOJ-1358 这题还是属于KMP算法的应用,属于字符串压缩问题.也就是在一个字符串s中寻找一个前缀,使得s可以被一份或者多份前缀子串t拷贝连接,也就是串接. #include< ...

  10. scramble-string——两个字符串经过树化并旋转后是否一致、递归、动态规划

    Given a string s1, we may represent it as a binary tree by partitioning it to two non-empty substrin ...

随机推荐

  1. 【贪心】AGC018C Coins

    Problem Link 现在有 \(X+Y+Z\) 个人,第 \(i\) 个人有三个权值 \(a_i,b_i,c_i\),现在要求依次选出 \(X\) 个人,\(Y\) 个人和 \(Z\) 个人(一 ...

  2. vue中keep-alive详细讲解

    场景 今天产品跑过来跟我说, 当我在A页面修改数据后,去B页面. 然后返回A页面.希望A页面保留我修改后的数据. 而不是数据又恢复最初的样子了.我心里想,尼玛,又要加班了? 看下面小粒子 数据被被重置 ...

  3. vm-insert到vm-storage链路上的配置说明

    作者:张富春(ahfuzhang),转载时请注明作者和引用链接,谢谢! cnblogs博客 zhihu Github 公众号:一本正经的瞎扯 本文是为了解决Victoria-Metrics中的过载问题 ...

  4. [P9253 [PA 2022] Ornitolog 2] 题解

    题目 P9253 [PA 2022] Ornitolog 2 题目描述 给你一个长度为 \(n\) 的数列,求至少要修改多少个数才能让数列成为交替鹡鸰鸟鸣的音高序列. 思路 这道题有两种情况. 第一种 ...

  5. Linux线程间交互

    前言 上一篇说过,系统会为线程mmap一块内存,每个线程有自己的私有栈,使用局部变量没啥问题.但是实际场景中不可避免的需要线程之间共享数据,这就需要确保每个线程看到的数据是一样的,如果大家都只需要读这 ...

  6. LyScript 计算片段Hash并写出Excel

    本案例将学习运用LyScript计算特定程序中特定某些片段的Hash特征值,并通过xlsxwriter这个第三方模块将计算到的hash值存储成一个excel表格,本例中的知识点可以说已经具备了简单的表 ...

  7. 守护线程(Python)

    import time from threading import Thread def son(): while True: print('in son') time.sleep(1) def so ...

  8. 关于React-Router6 (React 路由)

    一.概要 (1)每个单页应用其实是一系列的 JS 文件,当用户请求网站时,网站返回一整个(或一系列)的 js 文件和 HTML,而当用户在某个页面内点击时,你需要告诉浏览器怎么加载另一个页面地址.单页 ...

  9. 设计模式(三十二)----综合应用-自定义Spring框架-自定义Spring IOC-自定义Spring IOC总结

    1 自定义Spring IOC总结 1.1 使用到的设计模式 工厂模式.这个使用工厂模式 + 配置文件的方式. 单例模式.Spring IOC管理的bean对象都是单例的,此处的单例不是通过构造器进行 ...

  10. .NET Avalonia开源、免费的桌面UI库 - SukiUI

    前言 今天分享一款.NET Avalonia基于MIT License协议开源.免费的桌面UI库:SukiUI. Avalonia介绍 Avalonia是一个强大的框架,使开发人员能够使用.NET创建 ...