【LeetCode字符串#extra】KMP巩固练习:旋转字符串、字符串轮转
旋转字符串
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'。如果我们将s和s'进行比较,就会发现它们实际上是相同的字符串,只是从不同位置开始截取的。而这个位置的关系可以通过将goal复制一份连接到自身末尾来体现。举个例子:假设
s = "abcde",将s左移两位得到的新字符串是s' = "cdeab"。那么将goal复制一份连接到自身末尾,得到的字符串是goal + goal = "cdeababcde"。我们可以发现,在goal + goal中,第一个goal和s'是对应的,因为它们都是从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巩固练习:旋转字符串、字符串轮转的更多相关文章
- leetcode——Reverse Words in a String 旋转字符串中单词顺序(AC)
题目例如以下: Given an input string, reverse the string word by word. For example, Given s = "the sky ...
- 字符串匹配算法——KMP算法学习
KMP算法是用来解决字符串的匹配问题的,即在字符串S中寻找字符串P.形式定义:假设存在长度为n的字符数组S[0...n-1],长度为m的字符数组P[0...m-1],是否存在i,使得SiSi+1... ...
- c算法:字符串查找-KMP算法
/* *用KMP算法实现字符串匹配搜索方法 *该程序实现的功能是搜索本目录下的所有文件的内容是否与给定的 *字符串匹配,如果匹配,则输出文件名:包含该字符串的行 *待搜索的目标串搜索指针移动位数 = ...
- 【字符串】KMP字符串匹配
百度百科 Definition \(KMP\)算法是一个字符串匹配算法.他接收两个字符串\(A,B\),返回\(B\)在\(A\)中出现的所有位置. 以下称需要被匹配的串\(A\)为主串,可能在主串中 ...
- Leetcode 91. Decode Ways 解码方法(动态规划,字符串处理)
Leetcode 91. Decode Ways 解码方法(动态规划,字符串处理) 题目描述 一条报文包含字母A-Z,使用下面的字母-数字映射进行解码 'A' -> 1 'B' -> 2 ...
- 【字符串】KMP
Algorithm Task 给定一个文本串 \(S\) 和一个模式串 \(T\),求 \(T\) 在 \(S\) 中出现的所有位置. Limitations 要求时空复杂度均为线性. Solutio ...
- 算法数据结构 | 只要30行代码,实现快速匹配字符串的KMP算法
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是算法数据结构专题的第29篇文章,我们来聊一个新的字符串匹配算法--KMP. KMP这个名字不是视频播放器,更不是看毛片,它其实是由Kn ...
- [LeetCode]1249. 移除无效的括号(字符串,栈)
题目 给你一个由 '('.')' 和小写字母组成的字符串 s. 你需要从字符串中删除最少数目的 '(' 或者 ')' (可以删除任意位置的括号),使得剩下的「括号字符串」有效. 请返回任意一个合法字符 ...
- HDOJ-1358(字符串压缩+KMP)
Period HDOJ-1358 这题还是属于KMP算法的应用,属于字符串压缩问题.也就是在一个字符串s中寻找一个前缀,使得s可以被一份或者多份前缀子串t拷贝连接,也就是串接. #include< ...
- scramble-string——两个字符串经过树化并旋转后是否一致、递归、动态规划
Given a string s1, we may represent it as a binary tree by partitioning it to two non-empty substrin ...
随机推荐
- bcc工具的简要学习
摘要 继续补充假期落下的内容. 其实有很多知识需要学习, 自己掌握的还是偏少一些. bcc的全貌 # 注意 bcc 需要较高的内核. 3.10 系列的内核基本不可用. argdist drsnoop ...
- redis 6源码解析之 sds
redis使用sds(simple dynamic string)实现了字符串的存储.sds实际上就是TLV格式的数据结构.其数据结构主要分为如下5种,主要分为首部和数据部分,首部给出了type和le ...
- HBase深度历险 | 京东物流技术团队
简介 HBase 的全称是 Hadoop Database,是一个分布式的,可扩展,面向列簇的数据库,是一个通过大量廉价的机器解决海量数据的高速存储和读取的分布式数据库解决方案.本文会像剥洋葱一样,层 ...
- DPText-DETR: 基于动态点query的场景文本检测,更高更快更鲁棒 | 京东探索研究院
针对场景文本检测任务,近期基于DEtection TRansformer (DETR) 框架预测控制点的研究工作较为活跃.在基于DETR的检测器中,query的构建方式至关重要,现有方法中较为粗糙的位 ...
- 【dp,建模】AGC032D Rotation Sort
Problem Link 有一个长为 \(n\) 的排列 \(p\),给定 \(A,B\),你每次可以做以下两种操作之一: 选取 \(l,r\),将 \(p[l:r]\) 循环右移,代价为 \(A\) ...
- python快速入门【五】---- 面向对象编程、python类
python入门合集: python快速入门[一]-----基础语法 python快速入门[二]----常见的数据结构 python快速入门[三]-----For 循环.While 循环 python ...
- 1.6 编写双管道ShellCode
本文将介绍如何将CMD绑定到双向管道上,这是一种常用的黑客反弹技巧,可以让用户在命令行界面下与其他程序进行交互,我们将从创建管道.启动进程.传输数据等方面对这个功能进行详细讲解.此外,本文还将通过使用 ...
- php生成唯一订单号,高并发下不重复
//生成唯一订单号 function create_trade_no($prefix='dd') { return $prefix . date('YmdHis', time()) . substr( ...
- 教你用JavaScript实现粘性导航
案例介绍 欢迎来的我的小院,我是霍大侠,恭喜你今天又要进步一点点了!我们来用JavaScript编程实战案例,做一个粘性导航.移动页面导航仍在页面上方.通过实战我们将学会scrollY属性.offse ...
- 【实用小技巧】RSA非对称加解密及XML&PEM格式互换方案
最近因考虑接口安全问题,有实现给WEB API实现统一的参数鉴权功能,以防止请求参数被篡改或重复执行,参数鉴权方法基本与常见的鉴权思路相同,采用(timestamp+sign),而我为了防止tim ...