LeetCode Implement strStr()(Sunday算法)
2015-12-28 14:28
323 查看
LeetCode解题之Implement strStr()
原题
实现字符串子串匹配函数strStr()。如果字符串A是字符串B的子串,则返回A在B中首次出现的地址,否则返回-1。注意点:
- 空字符串是所有字符串的子串,返回0
例子:输入: haystack = “abc”, needle = “bc”
输出: 1
输入: haystack = “abc”, needle = “gd”
输出: -1
解题思路
字符串匹配常见的算法是KMP,不过感觉该算法理解困难,效率也不是特别高。我用了Sunday算法来实现字符串的匹配。大体思路如下:被搜索的字符串是”abcdefg”,要搜索的字符串是”ef”
[code] abcdefg ef
如果当前不匹配,则判断当前尝试匹配的后一位,即”c”是否在要搜索的字符串中,如果不在,则要搜索的字符串直接后移它自己的长度+1。
[code] abcdefg ef
如果存在,如此时”f”在”ef”中,则把该位置对齐。
[code] abcdefg ef
匹配成功返回结果。
AC源码
[code]class Solution(object): def strStr(self, haystack, needle): """ :type haystack: str :type needle: str :rtype: int """ if not needle: return 0 if not haystack: return -1 i = 0 needleLength = len(needle) while i < len(haystack): if haystack[i:i + needleLength] == needle: return i else: index = 0 try: index = needle.rindex(haystack[i + needleLength]) except Exception: i += needleLength + 1 i += needleLength-index return -1 if __name__ == "__main__": assert Solution().strStr("abcdefg", "ab") == 0 assert Solution().strStr("abcdefg", "bc") == 1 assert Solution().strStr("abcdefg", "cd") == 2 assert Solution().strStr("abcdefg", "fg") == 5 assert Solution().strStr("abcdefg", "bcf") == -1
欢迎查看我的Github来获得相关源码。
相关文章推荐
- bash 快捷键提示总结
- git使用ssh协议,生成公钥和私钥,并指定私钥
- CSS3学习记录四(动画-变形)
- cxf wsdl2java环境变量设置与使用
- 纯css实现警示框页面(带关闭窗口按钮)
- easyui datagrid
- 【shell脚本】监测局域网IP是否在线
- mysql报错解决MySQL Binlog(异常)——mysqlbinlog: unknown variable 'default-character-set=utf8'
- MySQL 5.7 传统复制到GTID在线切换
- springMVC两种方式实现多文件上传及效率比较
- 小故障
- 矩阵乘法
- 共享一个之前封装的多进程共享内存的MemoryStream
- 闲着没事做:程序员的核心竞争力是什么?为什么?
- Windows下更改MySQL数据库的存储位置
- 猫猫学iOS之UITextField全解
- json
- Jemter-订单发起后,每隔2S查询一次订单状态。若超过5分钟,停止查询,并返回订单状态
- 协同过滤的简单实现
- Android中对Log日志文件的分析