Implement wildcard pattern matching with support for '?' and '*'.

'?' Matches any single character.
'*' Matches any sequence of characters (including the empty sequence). The matching should cover the entire input string (not partial). The function prototype should be:
bool isMatch(const char *s, const char *p) Some examples:
isMatch("aa","a") → false
isMatch("aa","aa") → true
isMatch("aaa","aa") → false
isMatch("aa", "*") → true
isMatch("aa", "a*") → true
isMatch("ab", "?*") → true
isMatch("aab", "c*a*b") → false

题解:昨天晚上写了一晚上的递归,一直TLE。早上果断改用dp了,结果dp还TLE了好多次,真是说多了都是泪。

dp的思想很简单:用二维数组dp[s_length+1][p_length+1]记录结果。

  • 首先如果s和p都是空串的话,那么它们是匹配的,所以dp[0][0] = true;
  • 当s为空串的时候(dp中的第一行),dp[0][i] = p[i] == '*'? dp[0][i-1]:false;(i=1,...,p_length);
  • 对于任意j,如果p(j-1) == '*',dp[i][j]= dp[i-1][j] || dp[i][j-1],对应了两种情况,前一种是不匹配‘*’,后一种情况是匹配'*‘,如下图所示:
  • 如果p(j-1) != '*',则只有p(j-1) == '?'或者s(i-1) == p(j-1)的时候才有dp[i][j] = true;否则dp[i][j] = false;

开始以为这样就可以过了,事实证明I am too young too simple。这样还是会超时。要优化两个地方:

  • 数出p中不是'*'的字符个数,如果比s的总长度还长,那么s是没有办法匹配的,直接返回false;
  • 第二个优化让我非常无语,就是在实现循环的时候,不要每次用p.charAt(j)来取字符,要在开始用ch_p = p.charAt(j)把字符记下来,在以后的循环中就用这个,这么看来p.charAt(j)这个操作还是很耗时的,以后如果在程序中反复使用,都要把它存下来再使用。

最后AC的代码如下:

 public class Solution {
public boolean isMatch(String s, String p) {
int m = s.length();
int n = p.length(); int count = 0;
for(int indexP = 0;indexP<n;indexP++)
if(p.charAt(indexP) != '*')
count++;
if(count > m)
return false; boolean[][] dp =new boolean[m+1][n+1];
dp[0][0] = true; for(int j = 1;j<=n;j++)
{
char ch_p = p.charAt(j-1);
if(ch_p =='*' && dp[0][j-1])
dp[0][j]= true; for(int i= 1;i<=m;i++){
char ch_s = s.charAt(i-1);
if(ch_p =='*')
dp[i][j]= dp[i-1][j]|| dp[i][j-1];
else if(ch_p == '?' || ch_p == ch_s){
dp[i][j] = dp[i-1][j-1];
}
else
dp[i][j]= false;
}
}
return dp[m][n];
}
}

【leetcode刷题笔记】Wildcard Matching的更多相关文章

  1. LeetCode刷题笔记和想法(C++)

    主要用于记录在LeetCode刷题的过程中学习到的一些思想和自己的想法,希望通过leetcode提升自己的编程素养 :p 高效leetcode刷题小诀窍(这只是目前对我自己而言的小方法,之后会根据自己 ...

  2. 18.9.10 LeetCode刷题笔记

    本人算法还是比较菜的,因此大部分在刷基础题,高手勿喷 选择Python进行刷题,因为坑少,所以不太想用CPP: 1.买股票的最佳时期2 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. ...

  3. LeetCode刷题笔记 - 12. 整数转罗马数字

    学好算法很重要,然后要学好算法,大量的练习是必不可少的,LeetCode是我经常去的一个刷题网站,上面的题目非常详细,各个标签的题目都有,可以整体练习,本公众号后续会带大家做一做上面的算法题. 官方链 ...

  4. Leetcode刷题笔记(双指针)

    1.何为双指针 双指针主要用来遍历数组,两个指针指向不同的元素,从而协同完成任务.我们也可以类比这个概念,推广到多个数组的多个指针. 若两个指针指向同一数组,遍历方向相同且不会相交,可以称之为滑动窗口 ...

  5. 【leetcode刷题笔记】Regular Expression Matching

    Implement regular expression matching with support for '.' and '*'. '.' Matches any single character ...

  6. LeetCode刷题笔记(1-9)

    LeetCode1-9 本文更多是作为一个习题笔记,没有太多讲解 1.两数之和 题目请点击链接 ↑ 最先想到暴力解法,直接双循环,但是这样复杂度为n平方 public int[] twoSum(int ...

  7. leetcode刷题笔记

    (1)Best Time to Buy and Sell Stock Total Accepted: 10430 Total Submissions: 33800My Submissions Say ...

  8. leetcode刷题笔记08 字符串转整数 (atoi)

    题目描述 实现 atoi,将字符串转为整数. 在找到第一个非空字符之前,需要移除掉字符串中的空格字符.如果第一个非空字符是正号或负号,选取该符号,并将其与后面尽可能多的连续的数字组合起来,这部分字符即 ...

  9. LeetCode刷题笔记-回溯法-分割回文串

    题目描述: 给定一个字符串 s,将 s 分割成一些子串,使每个子串都是回文串. 返回 s 所有可能的分割方案. 示例: 输入: "aab"输出:[ ["aa", ...

随机推荐

  1. 大数据(4) - HDFS常用的shell操作

    注意:这次使用的是第二部分安装的集群,不是高可用集群 为了方便,开发,必须写集群脚本,试想集群的机器是100台以上,而不是3台的情况.... 集群启动脚本 vim /home/admin/tools/ ...

  2. php对gzip文件或者字符串解压实例参考

    要采集一个网站,目标站采用了gzip压缩传输网页,本来应该只要发送一个http头 Accept-Encoding: identity或者干脆不发送这个头等,就可以使目标站返回没有经过gzip压缩的页面 ...

  3. Node Embedding

    1.Kipf, Thomas N., and Max Welling. "Semi-supervised classification with graph convolutional ne ...

  4. 大量数据导入导致mysql自动重启

    昨天晚上第十款做数据库迁移,数据库版本:Version: '5.1.61',数据量27G左右 message报错信息如下: Mar :: VM_163_210_tlinux kernel: [, oo ...

  5. Ant Design使用问题记录

    公司的测试管理平台前端使用的是Ant Design of React框架,后台使用的是python,数据库用的是mysql.没有参与前期的开发,听说是工作了10年积累下来的一个暂且可用的管理平台,开发 ...

  6. sedna进行xquery查询

    有一个文件book.xml: <books> <book> <name>The Call Of Wild</name> <author>Ja ...

  7. Genealogical tree

    Genealogical tree Time Limit: 1000MS Memory Limit: 65536KTotal Submissions: 6032 Accepted: 3973 Spec ...

  8. 巨蟒python全栈开发django10:ajax&&登录认证

    通过题目进行知识点回顾: 聚合查询 From django.db.models import Avg,Min,Max,F,Q,Count,Sum #查询书籍的平均值 Ret= Models.Book. ...

  9. 分布式缓存的一致性Hash算法 2 32

    w 李智慧

  10. api xml database 设计一种数据库

    w 问题 0-新增和读取,可以忽略更新和删除: 1-被请求方的xml dom结构多层且不定,且未来可能增删某些键(dom节点),且键值长度最值可能无法确定: 3-请求过程可能出现异常exception ...