給定乙個字串 (s) 和乙個字元模式 (p) ,實現乙個支援 '?' 和 '*' 的萬用字元匹配。
'?' 可以匹配任何單個字元。
'*' 可以匹配任意字串(包括空字串)。
兩個字串完全匹配才算匹配成功。
說明:
s 可能為空,且只包含從 a-z 的小寫字母。
p 可能為空,且只包含從 a-z 的小寫字母,以及字元 ? 和 *。
示例 1:
輸入:
s = "aa"
p = "a"
輸出: false
解釋: "a" 無法匹配 "aa" 整個字串。
示例 2:
輸入:
s = "aa"
p = "*"
輸出: true
解釋: '*' 可以匹配任意字串。
示例 3:
輸入:
s = "cb"
p = "?a"
輸出: false
解釋: '?' 可以匹配 'c', 但第二個 'a' 無法匹配 'b'。
示例 4:
輸入:
s = "adceb"
p = "*a*b"
輸出: true
解釋: 第乙個 '*' 可以匹配空字串, 第二個 '*' 可以匹配字串 "dce".
示例 5:
輸入:
s = "acdcb"
p = "a*c?b"
輸出: false
大神果然很多,各種題目都能玩出花樣。 膜拜。。。。。
package com.atchina;
public class wildcardmatching
// 最簡單的版本
public static boolean ismatch1(string s, string p)
dp[0][x] = 1;
}//遍歷兩個字串,為dp[i][j]依次賦值
//dp[i][j]=true有三種可能
//(1)dp[i-1][j-1]=true並且s.charat(i-1)=p.charat(j-1) 或者p.charat(j-1) = 『?』
//(2)dp[i][j-1]=true並且p.charat(j-1)="*"
//(3)dp[i-1][j]=true並且p.charat(j-1)="*"
// s = "acdcb";
// p = "a*b"
for (int i=1; i<=m; i++)else if(p.charat(j)== '*')
}}else if(s.charat(i) == p.charat(j))}}
return dp[m][n] == 1 ? true : false;
}// 優化版1
public static boolean ismatch2(string s, string p)
dp[0][x] = 1;
}// s = "acdcb";
// p = "a*b"
for (int i=1; i<=m; i++)else if(p.charat(j)== '*')
// }
//dp[i][j-1] 即當前'*'匹配乙個空字元
//dp[i-1][j] 即當前'*'匹配乙個字元s.charat(i-1)
//這裡之所以不是dp[i-1][j-1]是因為當前'*'可能在前面已匹配了若干個字元
// 這裡進行優化,不使用迴圈
if(dp[i][j-1]== 1 || dp[i-1][j]== 1)else
}else if(s.charat(i) == p.charat(j))}}
return dp[m][n] == 1 ? true : false;
}// 優化版2 時間複雜度 o(n)
public static boolean ismatch(string s, string p)else if(pp}
// 處理最後字元是*的問題 比如 s = "abcefcb"; p="a*cb*",或者p="a*cb*****"等等
while(pp < p.length() && p.charat(pp) == '*')
return pp == p.length();
}}
leetcode。 44 萬用字元匹配
實現乙個支援 和 的萬用字元匹配。匹配任何單個字元。匹配任何數量的字元 包括0個 匹配應覆蓋 整個 輸入字串 而不是部分 這個函式原型為 bool ismatch const char s,const char p 示例 ismatch aa a false ismatch aa aa true i...
LeetCode44 萬用字元匹配
題目描述 給定乙個字串 s 和乙個字元模式 p 實現乙個支援 和 的萬用字元匹配。可以匹配任何單個字元。可以匹配任意字串 包括空字串 兩個字串完全匹配才算匹配成功。說明 思路一 字串p是模式字串,字串s是待匹配字串,使用p對s進行匹配。聯想到編輯距離那道題,使用兩個指標i和j,i指向字串s的第i個字...
LeetCode 44 萬用字元匹配
給定乙個字串 s 和乙個字元模式 p 實現乙個支援 和 的萬用字元匹配。可以匹配任何單個字元。可以匹配任意字串 包括空字串 兩個字串完全匹配才算匹配成功。說明 示例 1 輸入 s aa p a 輸出 false解釋 a 無法匹配 aa 整個字串。示例 2 輸入 s aa p 輸出 true解釋 可以...