使用KMP算法判断是否为旋转词
假设有两个字符串A、B,要判断它们是否为旋转词,只需构造一个“A+A”字符串,再与B比较,若B为A的旋转词,则使用KMP算法是可以得到结果的
代码如下:
import java.util.*;
public class test {
public static boolean chkRotation(String A, String B) {
if(A.length()!=B.length()) return false;
String buf =new String(A+A);
int flag;
flag=kmp(buf,B);
if(flag==-1) return false;
else return true;
}
/* public static void getNext(String str ){
int[] next=new int[str.length()];
next[0]=-1;
char[] chars=str.toCharArray();
int i=0;
int j=-1;在java里面不能这么写
//"前缀"指除了最后一个字符以外,一个字符串的全部头部组合;
//"后缀"指除了第一个字符以外,一个字符串的全部尾部组合。
while(i<str.length()){
if(j==-1||chars[i]==chars[j]){//此处的数组越界,报错
i++;
j++;
next[i]=j;
}
else
next[j]=j;
}
}
*/
public static int[] getNext(String str){
if(str.length()==-1) return new int[] {-1};
char[] chars=str.toCharArray();
int[] next=new int[str.length()];
next[0]=-1;
next[1]=0;
int pos=2;
int cn=0;
while (pos<str.length()){
if (chars[pos-1]==chars[cn]){
next[pos++]=++cn;
}
else if(cn>0) cn=next[cn];
else next[pos++]=0;
}
return next;
}
/*public static int kmp(String str, String pattern){
int i,j;
i=0;
j=0;
char[] chars=str.toCharArray();
int[] next=getNext(str);
while(i<str.length())
{
if(j==-1||chars[i]==chars[j])
{
i++;
j++;
}
else
{
j=next[j]; //消除了指针i的回溯
}
if(j==pattern.length())
return i-pattern.length();
}
return -1;
}
*/
public static int kmp(String ss,String ps){
if (ss.length()==0||ps.length()==0) return -1;
char[] chars=ss.toCharArray();
char[] charp=ps.toCharArray();
int i=0;//ss的指针
int j=0;//ps的指针
int[] next=getNext(ps);//这里相当于String B
while (i<ss.length()&&j<ps.length()){
if (j==-1||chars[i]==charp[j]){
i++;
j++;
}
else j=next[j];
}
if (j==ps.length()) return i-j;
else return -1;
}
public static int BFMatch(String str,String pattern){
char[] chars=str.toCharArray();
char[] charp=pattern.toCharArray();
/* int i=0; */
int charsi=0;
int charpi=0;
while(charsi<str.length()){
while(chars[charsi]==charp[charpi]){
charsi++;
charpi++;
}
if(charpi==str.length()-1)
return charsi-str.length();//找到匹配字符串中的匹配起始位置
charsi=charsi-charpi+1;
}
return -1;
}
public static void main(String[] args){
String str="RFSPUYLYR";
String pattern="UYLYRRFSP";
boolean f=chkRotation(str,pattern);
System.out.println(f);
System.exit(0);
}
}
如有不对欢迎指正!
使用KMP算法判断是否为旋转词的更多相关文章
- 算法之暴力破解和kmp算法 判断A字符串是否包含B字符串
我们都知道java中有封装好的方法,用来比较A字符串是否包含B字符串 如下代码,contains,用法是 str1.contains(str2), 这个布尔型返回,存在返回true,不存在返回fals ...
- 判断字符串a和b是否互为旋转词
旋转词:把字符串str的任意部分移动到后面形成的新字符串叫做字符串str的旋转词. 比如abc的旋转词有 abc,acb,cba,... 判断str1和str2是否互为旋转词,其最优解可以是时间复杂度 ...
- KMP算法浅析
具体参见: KMP算法详解 背景: KMP算法之所以叫做KMP算法是因为这个算法是由三个人共同提出来的,就取三个人名字的首字母作为该算法的名字.其实KMP算法与BF算法的区别就在于KMP算法巧妙的消除 ...
- 算法笔记之KMP算法
本文是<算法笔记>KMP算法章节的阅读笔记,文中主要内容来源于<算法笔记>.本文主要介绍了next数组.KMP算法及其应用以及对KMP算法的优化. KMP算法主要用于解决字符串 ...
- 萌新笔记——用KMP算法与Trie字典树实现屏蔽敏感词(UTF-8编码)
前几天写好了字典,又刚好重温了KMP算法,恰逢遇到朋友吐槽最近被和谐的词越来越多了,于是突发奇想,想要自己实现一下敏感词屏蔽. 基本敏感词的屏蔽说起来很简单,只要把字符串中的敏感词替换成"* ...
- 算法进阶面试题01——KMP算法详解、输出含两次原子串的最短串、判断T1是否包含T2子树、Manacher算法详解、使字符串成为最短回文串
1.KMP算法详解与应用 子序列:可以连续可以不连续. 子数组/串:要连续 暴力方法:逐个位置比对. KMP:让前面的,指导后面. 概念建设: d的最长前缀与最长后缀的匹配长度为3.(前缀不能到最后一 ...
- 用KMP算法与Trie字典树实现屏蔽敏感词(UTF-8编码)
前几天写好了字典,又刚好重温了KMP算法,恰逢遇到朋友吐槽最近被和谐的词越来越多了,于是突发奇想,想要自己实现一下敏感词屏蔽. 基本敏感词的屏蔽说起来很简单,只要把字符串中的敏感词替换成“***”就可 ...
- str_2.判断两个字符串是否互为旋转词
1. 字符串str的前面任意部分挪到后面形成的字符串叫做字符串str的旋转词 $str1 = "2ab1"; $str2 = "ab12"; $ret = is ...
- KMP算法解决字符串匹配问题
要解决的问题 假设字符串str长度为N,字符串match长度为M,M <= N, 想确定str中是否有某个子串是等于match的.返回和match匹配的字符串的首字母在str的位置,如果不匹配, ...
随机推荐
- ArcGIS制作放射状流向地图(Radial Flow Map)
流向地图火了,因为Facebook的那张著名的友邻图,抑或因为<数据可视化之美>中介绍飞行模式的航线图,总之,流向地图以它特殊的可视化形式,直观地展示事物之间的联系,尤其在展示网络流向.贸 ...
- ASP.NET MVC 5 - 给电影表和模型添加新字段
在本节中,您将使用Entity Framework Code First来实现模型类上的操作.从而使得这些操作和变更,可以应用到数据库中. 默认情况下,就像您在之前的教程中所作的那样,使用 Entit ...
- C语言 · 求矩阵各个元素的和
问题描述 这里写问题描述. 输入格式 测试数据的输入一定会满足的格式. 例:输入的第一行包含两个整数n, m,分别表示矩阵的行数和列数.接下来n行,每行m个正整数,表示输入的矩阵. 输出格式 要求用户 ...
- js实用篇之String对象
概述 String对象是JavaScript原生提供的三个包装对象之一,用来生成字符串的包装对象. var s1 = 'abc'; var s2 = new String('abc'); typeof ...
- Android开发学习之路-带文字的图片分享
有用过微信分享SDK的都应该知道,微信分享到朋友圈的时候是不能同时分享图片和文字的,只要有缩略图,那么文字就不会生效.那么问题就来了,如果我们想把APP内的某些内容连带图片一起分享到微信,是不是没办法 ...
- for 循环打印图形
public class For { public static void main(String[] args) { //"使用双层for循环打印图形时,外层管行,内层管列",那 ...
- iOS---iOS9搜索功能
前言 在iOS9之前我们只能使用Spotlight来搜索应用名称来打开指定App,而其他的内容都是提供给系统使用(信息,联系人,邮件等).在iOS9以后Apple允许开发者设置应用中任意内容可以被Sp ...
- android studio和eclipse中如何获取sha1值
首先如果是eclipse的话, 直接打开eclipse开发工具 那么接下来问题来了,现在很多开发者都已经从es转型到as开发工具了, 在android studio上没有直接提供这个GUI界面让我们去 ...
- 设置 iOS 应用的图标和名称
Xcode 8.1 设置 iOS 应用的图标和名称的方法: 设置应用图标: 1.在 Resources 中添加图片: 2.在 Icon file 的属性值填写图标文件的名称. 设置应用名: 1.修改 ...
- UpdateException-更新条目时出错分析
不屁话1张图搞定: 我是这个错: 2015-03-27 00:25:00,493 [9] ERROR log - System.Data.Entity.Infrastructure.DbUpdateE ...