当前位置: 首页 > news >正文

做网站规划小程序哪家好

做网站规划,小程序哪家好,好的做淘宝详情页的网站有哪些,电商网店运营一、题目概述 二、思路方向 在Java中,实现一个支持.和*的正则表达式匹配器,可以通过递归或动态规划(DP)的方法来完成。这里,我将使用动态规划的方法来解决这个问题,因为它更容易理解和实现。 动态规划的思…

一、题目概述

二、思路方向 

       在Java中,实现一个支持'.'和'*'的正则表达式匹配器,可以通过递归或动态规划(DP)的方法来完成。这里,我将使用动态规划的方法来解决这个问题,因为它更容易理解和实现。

       动态规划的思路是,我们可以创建一个二维的布尔数组dp,其中dp[i][j]表示字符串s的前i个字符和模式p的前j个字符是否匹配。初始化时,dp[0][0]true(空字符串和空模式匹配),而dp[0][j](对于所有j > 0)只有在p的前j个字符都是*时才为true,因为*可以匹配零个字符。

       接下来,我们遍历dp数组,填充剩余的条目。对于每个(i, j),我们考虑以下情况:

  1. 如果p[j-1]不是*,那么dp[i][j]为真当且仅当s[i-1] == p[j-1]p[j-1] == '.'dp[i-1][j-1]为真。
  2. 如果p[j-1]*,那么有两种可能性:
    • 忽略*和前面的字符,即看dp[i][j-2]
    • 匹配零个或多个前面的字符,这取决于dp[i-1][j](如果s[i-1]匹配p[j-2],则可以通过添加s[i-1]到匹配中)为真。

三、代码实现 

public class Solution {  public boolean isMatch(String s, String p) {  int m = s.length();  int n = p.length();  // 创建一个二维布尔数组dp  boolean[][] dp = new boolean[m + 1][n + 1];  dp[0][0] = true; // 空字符串和空模式匹配  // 初始化dp[0][j],只有当p全是*时才匹配  for (int j = 1; j <= n; j++) {  if (p.charAt(j - 1) == '*') {  dp[0][j] = dp[0][j - 2];  }  }  // 填充dp数组  for (int i = 1; i <= m; i++) {  for (int j = 1; j <= n; j++) {  if (p.charAt(j - 1) != '*') {  dp[i][j] = (s.charAt(i - 1) == p.charAt(j - 1) || p.charAt(j - 1) == '.') && dp[i - 1][j - 1];  } else {  // 两种情况:匹配0次或多次前面的字符  dp[i][j] = dp[i][j - 2]; // 忽略*和前面的字符  if (s.charAt(i - 1) == p.charAt(j - 2) || p.charAt(j - 2) == '.') {  dp[i][j] = dp[i][j] || dp[i - 1][j];  }  }  }  }  return dp[m][n];  }  public static void main(String[] args) {  Solution solution = new Solution();  System.out.println(solution.isMatch("aa", "a"));    // false  System.out.println(solution.isMatch("aa", "a*"));   // true  System.out.println(solution.isMatch("ab", ".*"));   // true  System.out.println(solution.isMatch("aab", "c*a*b")); // true  System.out.println(solution.isMatch("mississippi", "mis*is*p*.")); // false  }  
}

执行结果:

 四、小结 

       这个实现通过动态规划解决了正则表达式的匹配问题,时间复杂度为O(mn),空间复杂度也为O(mn),其中m和n分别是字符串s和模式p的长度。

 结语 

因为遇见你,我才知道我也能具有美丽的记忆。

所以,无论你怎样对待我,

我都会用心去宽恕你的恨

用心去铭记你的好

!!!

http://www.yayakq.cn/news/571227/

相关文章:

  • 网站建设案例 央视网阳泉建设网站的公司
  • 建设银行的官方网站电话网页设计与制作介绍
  • 请打开123720的网站百度中国建筑网招聘信息
  • 珠江网站建设做泌尿科网站价格
  • 网站开发做什么简单wordpress 企业建站
  • 全网营销一站式推广游戏交易网站开发
  • 上海建设银行网站查询余额网站建设信息科技公司
  • 想建设网站前期调研报告如何写网站模块分类
  • 网站程序怎么做创建免费论坛的10个网站
  • 网站开发技术方案与实施上海浦东注册公司
  • 做色网站黑龙江住建网
  • 灌南网站建设wordpress主题放在哪
  • 展览公司网站模板设计公司名字参考
  • 什么公司网站建设做的好电子科技大学网站开发制定合同
  • 通州微网站优化做网站怎么做多少钱
  • 唐山做网站公司哪家好网站建设需要交印花税吗
  • 公司主网站百度收录大量网站之类的信息旅游电子商务网站开发
  • 淘宝网 商务网站建设目的广西网站建设价格多少
  • 惠州网站建设如何网站搬迁
  • 提供专业网站建设平台一元手游平台app
  • 网站目录结构 权限查看网站浏览量
  • 提升网站流量该怎么做阿里云手机网站建设多少钱
  • 化妆网站模板下载免费如何制作购物网站
  • 网站域名绑定好处建筑公司做网站买空间多大合适
  • 做游戏网站需要多少钱如何制作微信小程序答题
  • 建网站报价明细表做网站需要会什么 知乎
  • 做国外搞笑网站精美旅游网站模板
  • 做网站用小公司还是大公司wordpress自动发现
  • 上海专业建网站公司竞价推广的方案
  • 网站自助建站旅游商城网站订单处理