Leetcode:44. Wildcard Matching

来源:http://www.cnblogs.com/lengender-12/archive/2017/05/12/6846090.html
-Advertisement-
Play Games

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


Description

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

Example

'?' 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
  • 思路二:迭代回溯,兩個指針
    • is:指向s的下一次迭代的位置,初始為同p的'*'對應位置,然後以後的每一次迭代加1
    • ip: 指向p的最近的一個'*'的位置

代碼

  • 遞歸超時。

    bool isMatch(string s, string p) {
        int slen = s.size(), plen = p.size();
        string pattern;
        int j = 0;
        while (j < plen){
            if (j > 0 && p[j] == '*' && p[j - 1] == p[j]){
                j++;
                continue;
            }
            pattern += p[j++];
        }
        return helper(s, slen, 0, pattern, pattern.size(), 0);
    }
    
    bool helper(string &s, int slen, int i, string &p, int plen, int j){
        if (i == slen && j == plen) return true;
        if (j == plen) return false;
        if (i == slen) return p[j] == '*' ? helper(s, slen, i, p, plen, j + 1) : false;
    
        if (s[i] == p[j] || p[j] == '?')
            return helper(s, slen, i + 1, p, plen, j + 1);
        else if (p[j] == '*'){
            bool flag = false;
            while (j + 1 < plen && p[j + 1] == p[j]) j++;
    
            flag = helper(s, slen, i + 1, p, plen, j);
            if (!flag && j + 1 < plen && (p[j + 1] == s[i] || p[j + 1] == '?'))
                flag = helper(s, slen, i, p, plen, j + 1);
    
            return flag;
        }
    
        else return false;
    }
  • 迭代回溯

    class Solution {
    public:
       bool isMatch(string s, string p) {
        int slen = s.size(), plen = p.size();
    
        int i = 0, j = 0, is = -1, ip = -1;
        while(i < slen){
            if(p[j] == '*'){
                is = i;
                ip = j++;
            }
            else{
                if(s[i] == p[j] || p[j] == '?'){
                    i++;
                    j++;
                }
                else if(ip == -1) return false;
                else {
                    i = ++is;
                    j = ip + 1;
                }
            }
        }
    
        while(j < plen && p[j] == '*') j++;
        return j == plen;
    }
    };

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 05 樹7:堆中的路徑 Description: 將一系列給定數字插入一個初始為空的小頂堆H[]。隨後對任意給定的下標i,列印從H[i]到根結點的路徑。 Input: 每組測試第1行包含2個正整數N和M(≤1000),分別是插入元素的個數、以及需要列印的路徑條數。下一行給出區間[ 10000, 10 ...
  • Given an array of integers, return indices of the two numbers such that they add up to a specific target. You may assume that each input would have ex ...
  • 輸出python3.x : print() 函數 >>> print('hello, world')使用print()函數或語句可以接受多個字元串,用逗號“,”隔開,就可以連成一串輸出。print()函數或語句會依次列印每個字元串,遇到逗號“,”會輸出一個空格>>> print('hello', ' ...
  • 一、java 開發環境的搭建 這裡主要說的是在windows 環境下怎麼配置環境。 1.首先安裝JDK java的sdk簡稱JDK ,去其官方網站下載最近的JDK即可。。http://www.oracle.com/technetwork/java/javase/downloads/jdk7-down ...
  • ———————————————————————相關文章———————————————————————————— 【Linux】nginx常用命令 【nginx】詳細配置說明 ———————————————————————相關文章———————————————————————————— 1.Nginx ...
  • ———————————————————————相關文章———————————————————————————— Centos之安裝Nginx及註意事項 【nginx】詳細配置說明 ———————————————————————相關文章———————————————————————————— ngin ...
  • int btn = (Button) findViewById(View.getId());//這句話中的btn不能用來和按鈕鍵Button的id號去比較 如果想存儲Button,可以這樣做: Stack<Button> btnStack = Stack<Button>();//創建一個存儲Butt ...
  • 前言:用於處理Java基本數據的轉換及進位轉換操作工具 一、實現功能 1、int預byte互轉 2、int與byte[]互轉 3、short與byte互轉 4、short與byte[]互轉 5、16位short與byte[]互轉 6、long預byte[]互轉 7、byte[]與inputstrea ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...