递归:当遇到我做了这一步,然后在看做下一步的情况时,需要考虑用递归。(或者出现多种可能性的时候)
#include<bits/stdc++.h> using namespace std; bool match(const char* s,const char* p){ //base case 两个字符串同时结束,返回true if((*p=='\0')&&(*s=='\0')){ return true; } //两个字符串中有一个先结束,返回false if((*p=='\0')||(*s=='\0')){ return false; } if(*p=='?'){ //?只能匹配数字和字符,如果当前遇到了?,又遇到了其他字符,返回false if(!isdigit(*s)&&!isalpha(*s)) return false; //遇到到 ? 则算匹配到一个字符,跳过一个位置 return match(s+1,p+1); }else if(*p=='*'){ //遇到连续多个*号,只有一个管作用(否则超时) while(*p=='*'){ p++; } p--; //遇到*号,匹配0个(str+1,str1不用动),匹配1个(str和str1都往前移动1位),匹配多个(str不用动,str+1) return match(s,p+1) || match(s+1,p+1) || match(s+1,p); }else if(tolower(*p)==tolower(*s)){//大小写不敏感 //当前两字符相等,则进行下一个字符的匹配 return match(s+1,p+1); } return false;//不满足上述三种情况,不匹配 } int main(){ string p,s; while(cin>>p>>s){ bool res = match(s.c_str(),p.c_str()); if(res){ cout<<"true"<<endl; }else{ cout<<"false"<<endl; } } return 0; }