Manacher演算法、KMP演算法
一、Manancher演算法
Manacher演算法用於查詢子串中的迴文,演算法維持的三個變數十分重要pArr(下標所在位置字元迴文長度)、index(迴文中心)、pR(迴文半徑),這種演算法比其他演算法效率高的原因在於,它可以利用前面已計算過的迴文來判斷是否需要計算迴文。演算法在字串每個字元之間已經開始和末尾都插入特殊字元(可以是任意字元包括所查字串中字元),在計算迴文時就避免了奇迴文和偶迴文的問題。
演算法程式碼:
public char[] manacherString(String str) {
char[] charArr = str.toCharArray();
char[] res = new char[str.length() * 2 + 1];
int index = 0;
for (int i = 0; i != res.length; i++) {
res[i] = (i & 1) == 0 ? '#' : charArr[index++];
}
return res;
}
public int maxLcpsLength(String str) {
if (str == null || str.length() == 0) {
return 0;
}
char[] charArr = manacherString(str);
int[] pArr = new int[charArr.length]; //下標所在位置字元迴文長度
int index = -1; //迴文中心
int pR = -1; //迴文半徑
int max = Integer.MIN_VALUE;
for (int i = 0; i != charArr.length; i++) {
pArr[i] = pR > i ? Math.min(pArr[2 * index - i], pR - i) : 1;
while (i + pArr[i] < charArr.length && i - pArr[i] > -1) {
if (charArr[i + pArr[i]] == charArr[i - pArr[i]])
pArr[i]++;
else {
break;
}
}
if (i + pArr[i] > pR) {
pR = i + pArr[i];
index = i;
}
max = Math.max(max, pArr[i]);
}
return max - 1;
}
二、KMP演算法
KMP演算法解決的是字串匹配問題,也是利用一個next陣列,利用前面的計算結果,為後面計算增加效率,next數字在KMP演算法中至關重要。
next陣列的定義:長度等於match字串長度
值為下標所在字元前面字串的標量(最長字首和最長字尾相等情況下的長度)
演算法程式碼
public int getIndexOf(String s, String m) {
if (s == null || m == null || m.length() < 1 || s.length() < m.length()) {
return -1;
}
char[] ss = s.toCharArray();
char[] ms = m.toCharArray();
int si = 0;
int mi = 0;
int[] next = getNextArray(ms); //生成next陣列
while (si < ss.length && mi < ms.length) {
if (ss[si] == ms[mi]) {
si++;
mi++;
} else if (next[mi] == -1) {
si++;
} else {
mi = next[mi];
}
}
return mi == ms.length ? si - mi : -1;
}
public int[] getNextArray(char[] ms) {
if (ms.length == 1) {
return new int[] { -1 };
}
int[] next = new int[ms.length];
next[0] = -1;
next[1] = 0;
int pos = 2;
int cn = 0;
while (pos < next.length) {
if (ms[pos - 1] == ms[cn]) {
next[pos++] = ++cn;
} else if (cn > 0) {
cn = next[cn];
} else {
next[pos++] = 0;
}
}
return next;
}
相關文章
- Manacher 演算法演算法
- Manacher演算法演算法
- Manacher 演算法演算法
- 【演算法】KMP演算法演算法KMP
- 演算法隨筆——manacher演算法
- Manacher演算法詳解演算法
- KMP 演算法KMP演算法
- KMP演算法KMP演算法
- 演算法(2)KMP演算法演算法KMP
- 專題十六 KMP & 擴充套件KMP & Manacher【Kuangbin】KMP套件
- Manacher(馬拉車演算法)演算法
- 演算法之KMP演算法KMP
- KMP, Manacher, SA 存在的意義KMP
- 演算法·理論:Manacher 筆記演算法筆記
- 白話 KMP 演算法KMP演算法
- 【演算法】KMP初識演算法KMP
- KMP演算法詳解KMP演算法
- 解讀KMP演算法KMP演算法
- 字串學習總結(Hash & Manacher & KMP)字串KMP
- KMP演算法和bfprt演算法總結KMP演算法
- 字串匹配演算法(三)-KMP演算法字串匹配演算法KMP
- 字串匹配-BF演算法和KMP演算法字串匹配演算法KMP
- KMP模式匹配演算法KMP模式演算法
- KMP字串匹配演算法KMP字串匹配演算法
- KMP演算法 Java實現KMP演算法Java
- 字串匹配演算法:KMP字串匹配演算法KMP
- “KMP、EXKMP、manacher、最小表示法”大雜燴KMP
- manacher || 擴充套件kmp -- Best Reward HDU - 3613套件KMP
- 模式匹配kmp演算法(c++)模式KMP演算法C++
- 演算法·理論:KMP 筆記演算法KMP筆記
- 字串匹配問題——KMP演算法字串匹配KMP演算法
- KMP演算法(Leetcode第28題)KMP演算法LeetCode
- 字串匹配之KMP《演算法很美》字串匹配KMP演算法
- [譯] Swift 演算法學院 - KMP 字串搜尋演算法Swift演算法KMP字串
- 字串匹配基礎下——KMP 演算法字串匹配KMP演算法
- 資料結構-KMP模式演算法資料結構KMP模式演算法
- kmp字串匹配,A星尋路演算法KMP字串匹配演算法
- 把KMP演算法嚼碎!(C++)KMP演算法C++
- 字串演算法--$\mathcal{KMP,Trie}$樹字串演算法KMP