字符串匹配方法

介紹兩種字符串匹配方法

1.暴力匹配

母串用s表示,長度為m

子串用p表示,長度為n

時間復雜度為:(m-n+1)n

算法:從s串的第一個字符開始匹配,若匹配,繼續根據p向后匹配,若后續的不匹配,s右移重新匹配p?

2.KMP算法

母串用s表示,長度為m

子串用p表示,長度為n

時間復雜度為:預處理階段m

算法:①計算next[]數組 ②字符串匹配

【參考】?

?http://kb.cnblogs.com/page/176818/

?http://www.cnblogs.com/gaochundong/p/string_matching.html

?http://blog.csdn.net/v_july_v/article/details/7041827?

【C語言實現】?

?1.暴力匹配

#include <stdio.h>
#include <string.h>
int main()
{
char *s="ASDFZGasdFZGdfasdFZGsdFZGFZG";
char *p="FZG";
int i=0,j=0,count=0;
int len_s=strlen(s);
int len_p=strlen(p);
while(i<len_s&&j<len_p)
{
if (s[i]==p[j])
{
i++;
j++;
}?
else
{
i=i-j+1;
j=0;
}
if (len_p==j)
{?

printf("%d\n",i-j);//打印匹配成功的起始位置?

count++;//計算匹配次數?
j=0;
}
}
printf("%d\n",count);//打印匹配次數
return 0;
}

?

?2.KMP算法?

#include <stdio.h>
#include <string.h>
int KmpSearch(char* s, char* p, int next[]);
void GetNext(char* p,int next[]);
int main()
{
char *s="asfdafASDdfda";
char *p="SD";
int next[3]={0};
GetNext(p,next);
KmpSearch(s,p,next);
return 0;
}
int KmpSearch(char* s, char* p, int next[]) ?
{ ?
int i = 0; ?
int j = 0; ?
int sLen = strlen(s); ?
int pLen = strlen(p); ?
while (i < sLen && j < pLen) ?
{ ?
//①如果j = -1,或者當前字符匹配成功(即S[i] == P[j]),都令i++,j++ ? ? ?
if (j == -1 || s[i] == p[j]) ?
{ ?
i++; ?
j++; ?
} ?
else ?
{ ?
//②如果j != -1,且當前字符匹配失敗(即S[i] != P[j]),則令 i 不變,j = next[j] ? ? ?
//next[j]即為j所對應的next值 ? ? ? ?
j = next[j]; ?
} ?
} ?
if (j == pLen)
{
printf("%d\n",i-j);//打印匹配成功的起始位置?
return i - j; ?
}
else ?
return -1; ?
}?
void GetNext(char* p,int next[]) ?//該函數為計算next[]數組,看不太懂。。。算法暫且先記住吧
{ ?
int pLen = strlen(p); ?
next[0] = -1; ?//第一位數字置為-1,其余的是最長公共元素右移一位
int k = -1; ?
int j = 0; ?
while (j < pLen - 1) ?
{ ?
//p[k]表示前綴,p[j]表示后綴 ?
if (k == -1 || p[j] == p[k]) ??
{ ?
++k; ?
++j; ?
next[j] = k; ?
} ?
else ??
{ ?
k = next[k]; ?
} ?
} ?
}

?

轉載于:https://www.cnblogs.com/kinghero/p/5604415.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/374469.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/374469.shtml
英文地址,請注明出處:http://en.pswp.cn/news/374469.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

區分幾進制的標志

自己總是記不住進制的開頭標記&#xff0c;就寫下來忘了就看看 1.二進制&#xff1a;Binary&#xff0c;數字以0b 、0B開頭 2.八進制&#xff1a;octal number system&#xff0c;數字自然以0打頭 3.十六進制&#xff1a;hexadecimal&#xff0c;以0x、0X開頭

每個人都知道MVC…

從一個最近的博客中&#xff0c;您可能已經了解到我最近一直在進行一些采訪&#xff0c;因為他們是針對Web應用程序開發人員的&#xff0c;所以我問的一個問題是“您能解釋一下MVC模式是什么嗎&#xff1f;”&#xff0c;值得稱贊的是&#xff0c;每個候選人知道答案。 對于不認…

php無限分類

無限循環 1.需要套2個foreach 2.2個foreach結構一樣 純代碼獲取數據 public function CycleData($parent_id0){$where[parent_id] $parent_id;$res $this->m->where($where)->field(id,name)->select();foreach($res as $k>$v){$result[$v[id]][id] $v[id];$r…

動態網頁數據的采集方案

我在上一篇文章中介紹了使用ScrapySharp快速從網頁中采集數據&#xff0c;這種方式是通過直接發送的Http請求來獲取的原始頁面信息&#xff0c;對于靜態網頁非常有效&#xff0c;但還有許多網站中的頁面內容并非全部存放在原始的頁面中&#xff0c;很多內容是通過javascript來動…

r語言ggplot2 多線圖繪制圖例_plotnine: Python版的ggplot2作圖庫

騰訊課堂 | Python網絡爬蟲與文本數據分析同樣的基本作圖任務&#xff0c;plotnine比matplotlib和seaborn代碼量少&#xff0c;更美觀。所以我又重新發一遍&#xff0c;大家可以先收藏起來&#xff0c;后面總有用到的時候~R語言的ggplot2繪圖能力超強&#xff0c;python雖有mat…

單元和集成測試的代碼覆蓋率

我最近在一個寵物項目中著手構建自動化的UI&#xff08;集成&#xff09;測試以及普通的單元測試。 我想將所有這些集成到我的Maven構建中&#xff0c;并提供代碼覆蓋率報告&#xff0c;以便我可以了解測試覆蓋率不足的區域。 我不僅發布了項目的源代碼&#xff0c;還整理了一個…

javascript事件與event對象的屬性

javascript事件列表解說事件瀏覽器支持解說一般事件onclickIE3、N2鼠標點擊時觸發此事件ondblclickIE4、N4鼠標雙擊時觸發此事件onmousedownIE4、N4按下鼠標時觸發此事件onmouseupIE4、N4鼠標按下后松開鼠標時觸發此事件onmouseoverIE3、N2當鼠標移動到某對象范圍的上方時觸發此…

感想

讀完三篇文章看到了前輩們的努力與堅持和對各自的學科的熱愛&#xff0c;以及各位前輩的奮斗的艱苦環境&#xff0c;我與那些前輩相比也許還達不到前輩們的那種級別&#xff0c;但是我的學習的條件卻比那些前輩們好的多&#xff0c;看完前輩們的奮斗史&#xff0c;以及前輩們的…

python學生分布_Python數據分析實戰之分布分析

前言 本文的文字及圖片來源于網絡,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯系我們以作處理。 作者&#xff1a;嚴小樣兒 分布分析法&#xff0c;一般是根據分析目的&#xff0c;將數據進行分組&#xff0c;研究各組別分布規律的一種分析方法。…

使用Spring Security 3.1保護RESTful Web服務,第3部分

1.概述 本教程顯示了如何使用Spring和基于Java的Spring Security 3.1來保護REST服務 。 本文將重點介紹如何使用“登錄和Cookie”方法專門針對REST API設置安全配置。 2. Spring Security的體系結構完全基于Servlet過濾器&#xff0c;因此&#xff0c;在HTTP請求處理方面&…

一次完整的HTTP請求所經歷的7個步驟

HTTP通信機制是在一次完整的HTTP通信過程中&#xff0c;Web瀏覽器與Web服務器之間將完成下列7個步驟&#xff1a; 1、建立TCP連接 在HTTP工作開始之前&#xff0c;Web瀏覽器首先要通過網絡與Web服務器建立連接&#xff0c;該連接是通過TCP來完成的&#xff0c;該協議與IP協議共…

jQuery基礎--樣式篇(3)

1.jQuiery對象與DOM對象   對于剛剛接觸jQuery的初學者&#xff0c;我們要清楚認識一點&#xff1a;jQuery對象與DOM對象是不一樣的。可能一時半會分不清楚哪些是jQuery對象&#xff0c;哪些是DOM對象&#xff0c;下面重點介紹一下jQuery對象&#xff0c;以及兩者相互間的轉換…

hls fifo_HLS優化方法DATAFLOW你用了嗎

上期內容&#xff1a;異步跨時鐘域電路該怎么約束DATAFLOW作為HLS的一種優化方法&#xff0c;對于改善吞吐率(Throughput)、降低延遲(Latency)非常有效。DATAFLOW的作用對象DATAFLOW可以作用于函數&#xff0c;也可以作用于for循環。如下圖所示(圖片來源Figure62, Figure 63, u…

Java 8虛擬擴展方法

我一直關注Java 8 Lambda表達式項目的發展已經有一段時間了&#xff0c;我對其當前的進展狀態感到非常興奮。 我發現的最新“易于理解”的演示文稿是這樣的&#xff1a; http://blogs.oracle.com/briangoetz/resource/devoxx-lang-lib-vm-co-evol.pdf 現在&#xff0c;作為一名…

python爬蟲 庫_七款必備的Python爬蟲庫,你知道幾個?

很多你需要的信息數據都是在網站內&#xff0c;雖然有些網站的數據會以整潔、結構化的形式呈現&#xff0c;但大部分網站卻無法做到這樣。因此&#xff0c;當你想要獲得一些數據的時候&#xff0c;你需要一些爬蟲工具幫助抓取&#xff0c;然后再對其進行分析。今天&#xff0c;…

62個Android Studio小技巧合集

轉載&#xff1a; 原文鏈接&#xff1a;http://laobie.github.io/android/2016/02/14/android-studio-tips.html轉載于:https://www.cnblogs.com/kesteler/p/5618490.html

在Hibernate,EhCache,Quartz,DBCP和Spring中啟用JMX

繼續使用JMX的過程&#xff08;請參閱&#xff1a; 人類JMX &#xff09;&#xff0c;我們將學習如何在一些流行的框架中啟用JMX支持&#xff08;通常是統計和監視功能&#xff09;。 這些信息大部分都可以在項目的主頁上找到&#xff0c;但是我決定在收集這些信息的同時&#…

二叉樹遍歷(前中后)

二叉樹前序遍歷&#xff1a; /*** Definition for binary tree* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/ class Solution { public:vector<int> preorderTravers…

python語言程序設計實踐教程答案實驗六_Python程序設計實踐教程

書名&#xff1a;Python程序設計實踐教程 定價&#xff1a;29.8 ISBN&#xff1a;9787115532602 作者&#xff1a;儲岳中 薛希玲 版次&#xff1a;*1版 出版時間&#xff1a;2020-04 內容提要&#xff1a; 本書是Python語言程序設計的配套實踐教材&#xff0c;分為三部分&#…

400多萬微信用戶如何“變現”?凱叔說了五大秘訣與教訓

凱叔&#xff0c;原名王凱&#xff0c;自媒體“凱叔講故事”創始人&#xff0c;近日在獅享家班委會上做了分享&#xff0c;全是實實在在的實驗性方法論。以下是王凱的分享內容&#xff0c;整理 / 垅青 我講的主題叫“基于內容的MVP探索”&#xff0c;MVP是什么東西&#xff1f;…