给定两个由英文字母组成的字符串 String 和 Pattern,要求找到 Pattern 在 String 中第一次出现的位置,并将此位置后的 String 的子串输出。如果找不到,则输出“Not Found”。

本题旨在测试各种不同的匹配算法在各种数据情况下的表现。各组测试数据特点如下:

  • 数据0:小规模字符串,测试基本正确性;
  • 数据1:随机数据,String 长度为 1,Pattern 长度为 1;
  • 数据2:随机数据,String 长度为 1,Pattern 长度为 1;
  • 数据3:随机数据,String 长度为 1,Pattern 长度为 1;
  • 数据4:随机数据,String 长度为 1,Pattern 长度为 1;
  • 数据5:String 长度为 1,Pattern 长度为 1;测试尾字符不匹配的情形;
  • 数据6:String 长度为 1,Pattern 长度为 1;测试首字符不匹配的情形。

输入格式:

输入第一行给出 String,为由英文字母组成的、长度不超过 1 的字符串。第二行给出一个正整数 N(≤),为待匹配的模式串的个数。随后 N 行,每行给出一个 Pattern,为由英文字母组成的、长度不超过 1 的字符串。每个字符串都非空,以回车结束。

输出格式:

对每个 Pattern,按照题面要求输出匹配结果。

输入样例:

abcabcabcabcacabxy
3
abcabcacab
cabcabcd
abcabcabcabcacabxyz

输出样例:

abcabcacabxy
Not Found
Not Found
//今年又是这样没时间来好好看最后的两道算法题。。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>typedef int Position;
#define NotFound -1void BuildMatch( char *pattern, int *match )
{Position i, j;int m = strlen(pattern);match[0] = -1;for ( j=1; j<m; j++ ) {i = match[j-1];while ( (i>=0) && (pattern[i+1]!=pattern[j]) )i = match[i];if ( pattern[i+1]==pattern[j] )match[j] = i+1;else match[j] = -1;}
}Position KMP( char *string, char *pattern )
{int n = strlen(string);int m = strlen(pattern);Position s, p, *match;if ( n < m ) return NotFound;match = (Position *)malloc(sizeof(Position) * m);BuildMatch(pattern, match);s = p = 0;while ( s<n && p<m ) {if ( string[s]==pattern[p] ) {s++; p++;}else if (p>0) p = match[p-1]+1;else s++;}return ( p==m )? (s-m) : NotFound;
}
int main() {char string[1000001] = {0};char pattern[1000001] = {0};scanf("%s\n", (char *)&string);int n;scanf("%d", &n);for(int i=0; i<n; i++) {scanf("%s\n", (char *)&pattern);Position p = KMP(string, pattern);if(p != NotFound) {if(i == n - 1) {printf("%s", (char *)string+p);} else {printf("%s\n", (char *)string+p);}} else {if(i == n - 1) {printf("Not Found");} else {printf("Not Found\n");}}}return 0;
}

转载于:https://www.cnblogs.com/wanghao-boke/p/10946367.html

KMP 串的模式匹配 (25 分)相关推荐

  1. 串的模式匹配(KMP算法)

    [问题描述] 串的模式匹配算法实现(KMP算法) [输入形式] 第一行输入主串s: 第二行输入模式串t: 第三行输入起始位置pos: [输出形式] 输出模式串t的next值(以空格分隔) 输出模式匹配 ...

  2. 7-3 sdust-Java-字符串集合求并集 (25 分)

    7-3 sdust-Java-字符串集合求并集 (25 分)从键盘接收N个英文字符串(其中不同的字符串数量大于10),从头开始取5个不同的字符串放入一个集合S1,然后接着取5个不同的字符串放入另一个集 ...

  3. 《数据结构》实验报告四:串的模式匹配(BF算法、KMP算法)

    一.实验目的 1.了解串的基本概念. 2.掌握串的模式匹配算法的实现 . 二.实验预习 说明以下概念 1.模式匹配: 串的模式匹配就是子串的定位运算. 设有两个字符串 S 和 T ,S为主串(正文串) ...

  4. python 1070 结绳 (25 分) 给定一段一段的绳子,你需要把它们串成一条绳。每次串连的时候,是把两段绳子对折,再如下图所示套接在一起。这样得到的绳子又被当成是另一段绳子,可以再次对折去跟另

    Python 1070 结绳 (25 分) 解题思路呢就是:长度很长的绳子如果一直对折只会越折越短而且短的相较长度不长的绳子要短得多,即长绳子对折比短绳子损耗的更多,如果要想获得最后尽可能长的绳子,就 ...

  5. KMP算法字符串模式匹配

    KMP字符串模式匹配详解 来自CSDN     A_B_C_ABC 网友 KMP字符串模式匹配通俗点说就是一种在一个字符串中定位另一个串的高效算法.简单匹配算法的时间复杂度为O(m*n);KMP匹配算 ...

  6. 从病毒感染检测谈串的模式匹配

    病毒感染检测:串的模式匹配 BF.KMP算法 在网络入侵检测.计算机病毒特征码匹配以及DNA序列匹配等应用中都需要进行串的模式匹配.针对这个问题,书上讲了两种模式匹配的算法,即BF算法和KMP算法,下 ...

  7. 7-14 电话聊天狂人 (25 分)map做法 + 详解 + 思路分析

    7-14 电话聊天狂人 (25 分)map做法 1:题目 给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人. 输入格式: 输入首先给出正整数N(≤10 ​5 ​​ ),为通话记录条数.随后N行 ...

  8. C++学习之路 | PTA乙级—— 1070 结绳 (25 分)(精简)

    1070 结绳 (25 分) 给定一段一段的绳子,你需要把它们串成一条绳.每次串连的时候,是把两段绳子对折,再如下图所示套接在一起.这样得到的绳子又被当成是另一段绳子,可以再次对折去跟另一段绳子串连. ...

  9. 7-47 对称排序 (25 分)

    7-47 对称排序 (25 分) 你供职于由一群丑星作为台柱子的信天翁马戏团.你刚完成了一个程序编写,它按明星们姓名字符串的长度非降序(即当前姓名的长度至少与前一个姓名长度一样)顺序输出他们的名单.然 ...

最新文章

  1. Java根据学号提取班级_学生成绩管理系统 1. 能够实现根据以下关键字查询:学生姓名 、学号、班级、课 联合开发网 - pudn.com...
  2. 10067mysql_MYSQL数据库mysql Non-Transactional Database Only(只支持MyISAM)
  3. Ehcache整合spring配置
  4. MFC 程序大小及控件自适应不同的屏幕分辨率
  5. php之使用file_get_contents对百度orc进行文字识别(二维码识别同理)--base64编码方式(解决image format error)
  6. 单片机跑马灯12种c语言程序设计,基于单片机多模式带音乐跑马灯设计附完整程序代码.doc...
  7. 记一次js调试(attachEvent, onchange, onpropertychange)
  8. 音乐类Demo资源大全
  9. 台式计算机搜索不到无线信号,台式机无线搜不到怎么办
  10. 浅析统一操作系统UOS与深度Deepin区别
  11. 链家房源数据爬取(Scrapy)
  12. Mac恢复系统更新命令
  13. 计算机的简单手抄报图片,简单a4手抄报模板设计图
  14. 用C语言根据出生年月日判断年龄
  15. 浅谈微分求导+泰勒展开+生成函数
  16. android user-agent iso-8859-1,微信大众,平台消息接口开辟(31)微信浏览器HTTP_USER_AGENT断定...
  17. HTML如何设置幻灯片大小和位置,javascript – 动态调整skitter幻灯片图像大小
  18. vue mounted
  19. 如何在 IDEA 中创建并部署 JavaWeb 程序
  20. ROP_Emporium_write4

热门文章

  1. Linux中vim编辑器的缩进的功能键
  2. Photoshop 保存PNG格式交错和不交错有差别
  3. php如何清理网站缓存,php怎么清除opcache缓存
  4. FC冒险岛java版_冒险岛单机版
  5. python 编码声明位置,python中的编码声明
  6. python自带sqlite库_Python标准库之sqlite3使用实例
  7. java中不能定义为变量名称_Java,“变量名”不能解析为变量
  8. java 条码识别_条码识别示例代码
  9. 系统英伟达gpu驱动卸载_绕过CPU,英伟达让GPU直连存储设备
  10. coreos 安装mysql_CoreOS 在 PC 上快速安装方法指南