奶头挺立呻吟高潮av全片,成人试看120秒体验区,性欧美极品v,A片高潮抽搐揉捏奶头视频

C語言

C語言中實現KMP算法實例

時間:2025-04-03 21:53:56 C語言 我要投稿
  • 相關推薦

C語言中實現KMP算法實例

  一般的算法為什么這么低效呢?那是因為主串指針回溯情況過多:

  主串指針如果不回溯的話,速度就會加快,那我們就會想:

  如何讓主串指針不回溯?

  KMP算法就是解決了這個問題,所以速度變得更快速了。

  它是這樣子的:

  用一個數組:next[] 求得失配時的位置,然后保存下來。

  要說清楚KMP算法,可以從樸素的模式匹配算法說起。

  樸素的模式匹配算法比較容易理解,其實現如下

  int Index(char s[], char p[], int pos) { int i, j, slen, plen; i = pos; j = 0; slen = strlen(s); plen = strlen(p); while((i < slen) && (j < plen)) { if((s[i] == p[j])) { i++; j++; } else { i = i-j+1; j = 0; } } if(j >= plen) { return (i-plen); } else { return -1; } }

  可見,在樸素的模式匹配算法中,當模式中的p[j]與主串中的s[i]不匹配時,需要把主串的指針回溯到i-j+1的地方從新用s[i-j+1]跟p[0]進行匹配比較。KMP算法的想法是,能不能不回溯主串的指針呢?這種想法基于如下事實的:p[j]!=s[i]前,p[0]~p[j-1]跟s[i-j]~s[i-1]是匹配的(這里j>0,也就是說在不匹配前已經有匹配的字符了。否則如果j=0,則主串指針肯定不用回溯,直接向前變成i+1再跟p[0]比較就是了)

  p[j]!=s[i]前,p[0]~p[j-1]跟s[i-j]~s[i-1]是匹配的,這說明了什么呢?這說明可以通過分析模式的p[0]~p[j-1]來分析s[i-j]~s[i-1]。如果模式中存在p[0]~p[k-1]=p[j-k]~p[j-1](共k個匹配的字符,且k是滿足這個關系的最大值),則可以知道s[i-k]~s[j-1]跟[0]~p[k-1]是匹配的,那么,s[i]只需要跟p[k]進行比較就行了。而這個k是跟主串無關的,只需要分析模式串就可以求出來(這就是普通的教材中next[j]=k這個假設的由來,普通教材中總喜歡假設這個k值已經有了,如果你邏輯思維強還沒有什么,不然或多或少會把你卡在這的)。亦即next[j]=k。

  如果上述的p[0]~p[k-1]=p[j-k]~p[j-1]串不存在會怎么樣呢?這說明p[j]前的串中不存在p[0]...=...p[j-1]的情況,就連p[0]也不等于p[j-1],也就是說p[0]~p[j-1]中所有以p[j-1]為結尾的子串跟模式p都是失配的。基于上面p[0]~p[j-1]=s[i-j]~s[i-1]的事實,可以斷定s[i-j]~s[i-1]中所有以s[i-1]結尾的子串跟模式p都是失配,這說明把主串的指針回溯到i-j+1~i-1都是沒有必要的,既然沒有必要回溯,而s[i]!=p[j],則s[i只能跟p[0]進行比較匹配了。亦即next[j]=0。

  特殊情況下,j=0,即s[i]!=p[0],這時不用再用s[i]來跟p中的其它字符比較了,變成用s[i+1]跟p[0]進行比較。為了統一,可以讓next[0]=-1。在下一輪的比較中,判斷到j=-1的情況時,讓i=i+1,j=j+1,自然就形成s[i+1]跟p[0]比較的效果了。

  KMP算法實現示例

  具體請看如下程序:

  #include#include#include#define MAX 101void get_next( int *next,char *a,int la) /*求NEXT[]的值*/{ int i=1,j=0 ; next[1] = 0 ; while ( i <= la) /*核心部分*/ { if( a[i] == a[j] || j == 0 ) { j ++ ; i ++ ; if( a[i] == a[j]) next[i] = next[j]; else next[i] = j ; } else j = next[j] ; }}int str_kmp( int *next, char *A ,char *a, int lA,int la)/* EASY*/{ int i,j,k ; i = 1 ; j = 1 ; while ( i<=lA && j <= 0="" la="" j="" i="" else="" if=""> la) return i-j+1 ; else return -1 ;}int main(void){ int n,k; int next[MAX]={0} ; int lA=0,la =0 ; char A[MAX],a[MAX] ; scanf("%s %s",A,a) ; lA = strlen(A); la = strlen(a); for(k=la-1; k>= 0 ;k --) a[k+1] = a[k] ; for(k=lA-1; k>= 0 ;k --) A[k+1] = A[k] ; get_next(next,a,la) ; k = str_kmp(next,A,a,lA,la); if ( -1 == k) printf("Not Soulation!!! "); else printf("%d ",k) ; system("pause"); return 0 ;}

【C語言中實現KMP算法實例】相關文章:

c語言中關于使用BF-KMP算法實例01-16

KMP算法的C#實現方法04-11

c#實現sunday算法實例08-07

c#實現輪詢算法實例代碼05-31

C#實現協同過濾算法的實例代碼06-19

C語言實現歸并排序算法實例03-19

C語言中使用快速排序算法對元素排序的實例06-20

C語言實現歸并排序算法實例分析06-28

C語言中實現“17進制”轉“10進制”代碼(實例)07-06

主站蜘蛛池模板: 洛隆县| 临沭县| 上蔡县| 广平县| 甘孜县| 枣强县| 和林格尔县| 贡觉县| 江川县| 淄博市| 获嘉县| 上犹县| 湖北省| 宁南县| 霍城县| 淄博市| 洪洞县| 锦州市| 睢宁县| 平定县| 苏尼特左旗| 衡南县| 南部县| 福鼎市| 芦溪县| 苍南县| 牡丹江市| 容城县| 香港 | 麦盖提县| 三门县| 漯河市| 南靖县| 瑞金市| 松江区| 柳林县| 黔江区| 兖州市| 平顶山市| 昔阳县| 阿图什市|