-
Lesson 1 - 最简单的C程序
-
Lesson 2 - 打印输出
-
Lesson 3 - 循环打印
-
Lesson 4 - 判断奇偶
-
Lesson 5 - 从1加到100求和
-
Lesson 6 - 乘法表
-
Lesson 7 - 求100以内的最大素数
-
Lesson 8 - 1到100有多少个9
-
Lesson 9 - 整型转字符串
-
Lesson 10 - 约瑟夫环
-
Lesson 11 - 求两个坐标点之间的距离
-
Lesson 12 - 判断机器存储是否小尾端
-
Lesson 13 - 对不起,你的车今天限行
-
Lesson 14 - 判断地图上某点是否有出路
-
Lesson 15 - 统计一个数二进制表示中1的个数
-
Lesson 16 - 字符串拷贝
-
Lesson 17 - 统计单词个数
-
Lesson 18 - 实现 printf
-
Lesson 19 - 命令解释器
-
Lesson 20 - 预处理器实现
-
Lesson 21 - 词法分析器实现
-
Lesson 22 - 猜数游戏
-
Lesson 23 - 五子棋
-
Lesson 24 - 超链接分析器
-
Lesson 25 - cp命令实现
-
Lesson 26 - ELF文件头分析器实现
-
Lesson 27 - 简单流处理器实现和正则表达式
-
Lesson 28 - 数学计算器实现
-
Lesson 29 - 数学计算器实现more命令实现
-
Lesson 30 - sort命令实现
-
Lesson 31 - ls -l命令实现
-
Lesson 32 - Bash项目
-
Lesson 33 - 动态数组实现
-
Lesson 34 - 约瑟夫环问题
-
Lesson 35 - 表达式求值问题
-
Lesson 36 - 广度优先解决迷宫问题
-
Lesson 37 - 词频统计器
-
Lesson 38 - 堆排序问题
-
Lesson 39 - 构造符号表
-
Lesson 40 - MyDictionary项目
-
Lesson 41 - BSearch 实现
-
Lesson 42 - QSort 实现
-
Lesson 43 - 深度优先解决迷宫问题
-
Lesson 44 - KMP 算法实现
-
Lesson 45 - 最长公共子序列(LCS)问题
-
Lesson 46 - Dijkstra 算法
-
Lesson 47 - Huffman Coding 算法
-
Lesson 48 - 地图导航项目
Lesson 44 - KMP 算法实现
课程任务
参考 Knuth-Morris-Pratt 字符串查找算法,实现字符串查找的 KMP 算法。
重要结论:
- 当比较过程中发生不匹配时,不需要把搜索位置移回到已经比较过的位置,可以根据前面比较过字符中所包含的部分匹配信息(partial match),向后移动较多位置,从而提高比较效率。
- 部分匹配表的作用就是计算向后移动的位数=已匹配的字符数-对应的部分匹配值
- 最后一个元素的部分匹配值为0,表示找到一个完全匹配,跳过整个匹配字符串继续向后搜索。
- 部分匹配的本质就是字符串的头部和尾部会有重复,重复部分的长度等于最长的前缀后缀共有元素长度,每次不匹配时需要向后移动的长度就是要确保这个匹配(即前缀和后缀的最多共有元素产生相同比较)能够发生。
参考资料
- 字符串匹配的KMP算法 http://www.ruanyifeng.com/blog/2013/05/Knuth%E2%80%93Morris%E2%80%93Pratt_algorithm.html
- 字符串匹配的Boyer-Moore算法 http://www.ruanyifeng.com/blog/2013/05/boyer-moore_string_search_algorithm.html
- Knuth-Morris-Pratt string matching http://www.ics.uci.edu/~eppstein/161/960227.html
- Knuth-Morris-Pratt (KMP) String Search Algorithm source code http://www.cprogramming.com/snippets/source-code/knuthmorrispratt-kmp-string-search-algorithm