sdut 2125串结构练习--字符串匹配【两种KMP算法】
串结构练习——字符串匹配
Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^
题目链接:http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2125
题目描述
输入
输出
示例输入
- abc
- a
- 123456
- 45
- abc
- ddd
示例输出
- YES
- YES
- NO
提示
代码:
- #include<string.h>
- #include<iostream>
- using namespace std;
- char S[],T[];
- int s,t,next[],nextval[];
- void get_next(char T[],int next[]);//对应模式匹配算法一next函数值
- void get_nextval(char T[],int nextval[]);//对应模式匹配算法二nextval函数值
- int Index_KMP(char S[],char T[],int pos);//模式匹配算法一
- int Index_KMP2(char S[],char T[],int pos);//模式匹配算法二
- int main()
- {
- while(cin>>S>>T)
- {
- memset(next,,sizeof(next));
- int i;
- s=strlen(S);
- t=strlen(T);
- for(i=s;i>=;i--)
- S[i]=S[i-];
- S[s+]='\0';
- for(i=t;i>=;i--)
- T[i]=T[i-];
- T[t+]='\0';
- //get_next(T,next);
- get_nextval(T,nextval);
- //int flag=Index_KMP(S,T,1);//通过这里可以验证两个算法
- int flag=Index_KMP2(S,T,);
- //for(i=1;i<=t;i++)
- // cout<<nextval[i]<<" ";
- //cout<<endl;
- if(flag==)cout<<"NO"<<endl;
- else cout<<"YES"<<endl;
- }
- return ;
- }
- void get_next(char T[],int next[])//对应模式匹配算法一next函数值
- {
- int i=,j=;
- next[]=;
- while(i<t)
- {
- if(j==||T[i]==T[j])
- {
- ++i;
- ++j;
- next[i]=j;
- }
- else j=next[j];
- }
- }
- void get_nextval(char T[],int nextval[])//对应模式匹配算法二nextval函数值
- {
- int i=,j=;
- nextval[]=;
- while(i<t)
- {
- if(j==||T[i]==T[j])
- {
- ++i;
- ++j;
- if(T[i]!=T[j])
- nextval[i]=j;
- else
- nextval[i]=nextval[j];
- }
- else
- j=nextval[j];
- }
- }
- int Index_KMP(char S[],char T[],int pos)//模式匹配算法一
- {
- int i=pos,j=;
- while(i<=s&&j<=t)
- {
- if(j==||S[i]==T[j])
- {
- ++i;
- ++j;
- }
- else j=next[j];
- }
- if(j>t)return i-t;
- else return ;
- }
- int Index_KMP2(char S[],char T[],int pos)//模式匹配算法二
- {
- int i=pos,j=;
- while(i<=s&&j<=t)
- {
- if(j==||S[i]==T[j])
- {
- ++i;
- ++j;
- }
- else j=nextval[j];
- }
- if(j>t)return i-t;
- else return ;
- }
sdut 2125串结构练习--字符串匹配【两种KMP算法】的更多相关文章
- 模式字符串匹配问题(KMP算法)
这两天又看了一遍<算法导论>上面的字符串匹配那一节,下面是实现的几个程序,可能有错误,仅供参考和交流. 关于详细的讲解,网上有很多,大多数算法及数据结构书中都应该有涉及,由于时间限制,在这 ...
- 神奇的字符串匹配:扩展KMP算法
引言 一个算是冷门的算法(在竞赛上),不过其算法思想值得深究. 前置知识 kmp的算法思想,具体可以参考 → Click here trie树(字典树). 正文 问题定义:给定两个字符串 S 和 T( ...
- SDUT OJ 数据结构实验之串二:字符串匹配
数据结构实验之串二:字符串匹配 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descrip ...
- [小专题]另一种字符串匹配的思路——Shift-And算法
吐槽:前两天打组队赛遇到一个字符串的题考了这个(见:http://acm.hdu.edu.cn/showproblem.php?pid=5972 ) 当时写了个KMP瞎搞然后TLE了(害),赛后去查了 ...
- Java的IO操作中有面向字节(Byte)和面向字符(Character)两种方式
解析:Java的IO操作中有面向字节(Byte)和面向字符(Character)两种方式.面向字节的操作为以8位为单位对二进制的数据进行操作,对数据不进行转换,这些类都是InputStream和Out ...
- 数据结构- 串的模式匹配算法:BF和 KMP算法
数据结构- 串的模式匹配算法:BF和 KMP算法 Brute-Force算法的思想 1.BF(Brute-Force)算法 Brute-Force算法的基本思想是: 1) 从目标串s 的第一个字 ...
- I两种冒泡算法
两种冒泡算法: 第一个循环,I 定位当前坐标,第二个循环 把 I 之后的每个数都与 I 比较(比 I 小的都去坐标I),第二个循环之后 坐标 I 为数组里最小的数值. 效率比较高的冒泡算法: stat ...
- C++多字节字符转换为宽字符的两种方法
目前知道有两种方式:可以提供宽字符与ANSI字符之间的转换, 第一种由COM库提供的函数 char* _com_util::ConvertBSTRToString(BSTR ); BSTR _com ...
- JavaScript 区分中英文字符的两种方法: 正则和charCodeAt()方法
正则无疑是最强大的判断各种条件的方法, 最近也在研习它, 虽然枯燥, 但仍有乐趣. 用它来判断一个双字节的中文字符也是轻而易举地. 而判断中文字符, 简单且执行效率高. regExpForm.onb ...
随机推荐
- BZOJ 1922: [Sdoi2010]大陆争霸
Description 一个无向图,到一个点之前需要先到其他点,求从第一个点到第 \(n\) 点最短时间. Sol 拓扑+Dijkstra. 跑Dijkstra的时候加上拓扑序... 用两个数组表示 ...
- QT 信号与槽connect
QT 信号与槽connect QT 信号与槽connect connect函数调用几个限制 connect函数代码 QT中信号与槽的连接使用的connect函数是一个静态函数,在类QObject中定义 ...
- centos7 & mysql
首先centos7很坑爹. 其次,在centos7上安装mysql更坑爹. 特此记录一次坑爹历程后的唯一出路. 安装mysql wget http://repo.mysql.com/mysql-com ...
- putty快速设置本地代理
sudo plink -D 127.0.0.1:8888 -l root -P 443 -pw xxx 104.xxx.xxx.xxx
- phalcon 前端代码结构
phalcon 前端举例: (1) baisic.phtml + basic_ajax_get.phtml + basic_ajax_post.phtml (2) basic_get.phtml ...
- Additive Number
Additive number is a string whose digits can form additive sequence. A valid additive sequence shoul ...
- c#.net Excel中的数据导入到SQL数据库中
/// <summary> /// 从Excel 导入学生 /// </summary> /// <param name=&qu ...
- pip安装简单方法
前提:有网络 wget -c --no-check-certificate https://bootstrap.pypa.io/get-pip.py python get-pip.py
- jQuery获取循环中的选中单选按钮radio的值
1.<input type="radio" name="testradio" value="jquery获取radio的值" /> ...
- [Linux]centOS7下RPM安装Perl
1.下载rpm依赖包,依照顺序安装. perl-parent-0.225-244.el7.noarch perl-HTTP-Tiny-0.033-3.el7.noarch perl-podla ...