Chinaunix首页 | 论坛 | 博客
  • 博客访问: 266702
  • 博文数量: 170
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1709
  • 用 户 组: 普通用户
  • 注册时间: 2014-05-06 18:01
文章分类

全部博文(170)

文章存档

2016年(11)

2015年(130)

2014年(29)

分类: Java

2015-08-04 20:52:48

//Implement regular expression matching with support for '.' and '*'.
//
//'.' Matches any single character.
//'*' Matches zero or more of the preceding element.
//
//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", "a*") → true
//isMatch("aa", ".*") → true
//isMatch("ab", ".*") → true
//isMatch("aab", "c*a*b") → true
public class RegulaExpressionMatching {


public static void main(String[] args) {
// TODO Auto-generated method stub
isMatch("aaa", "ab*a*c*a");
}
 public static boolean isMatch(String s, String p) {
//    int i=0;
//    int j=0;
//    char before = '\0';
//    //两个都要判断
//    while(i<s.length()&&j<p.length()){
//     if(s.charAt(i)==p.charAt(j)||p.charAt(j)=='.'){
//     //直接取值 取p的值
//     before=p.charAt(j);
//     i++;
//     j++;
//    
//     }else{
//     //判断前一个是.
//     if(p.charAt(j)=='*'&&(s.charAt(i)==before||before=='.')){
//     i++;
//    
//     }else if(p.charAt(j)=='*'){
//     j++;
//     //出现"aaa", "a*a" 注意j<p.length() 先保存前一个的值
//     while(j<p.length()&&p.charAt(j)==before){
//        before=p.charAt(j);
//     j++;
//    
//     }
//     before='\0';
//     }else if(j+1<p.length()&&p.charAt(j+1)=='*'){
//     j=j+2;
//     }else {
// return false;
// }
//    
//    
//     }
//    
//    }
//    //每次用j注意判断
//    
//    
//
//
//    
//    
//    //每种都做判断
//    if(i<s.length()&&j>=p.length())
//     return false;
//    if(i>=s.length()&&j>=p.length())
//     return true;
//    if(p.charAt(j)=='*')
//     j++;
//    //出现"aaa", "a*a" 注意j<p.length()
//    while(j<p.length()&&p.charAt(j)==before){
//    before=p.charAt(j);
// j++;
//    }
//    while(j<p.length()){
//     if(p.charAt(j)!='*'&&j+1<p.length()&&p.charAt(j+1)=='*')
//     j=j+2;
//     else
//     return false;
//    }
//    return true;
//改的醉了。。。
 if(p.length() == 0)
           return s.length() == 0;
 
       //p's length 1 is special case    
       if(p.length() == 1 || p.charAt(1) != '*'){
           if(s.length() < 1 || (p.charAt(0) != '.' && s.charAt(0) != p.charAt(0)))
               return false;
           return isMatch(s.substring(1), p.substring(1));    
 
       }else{
           int len = s.length();
 
           int i = -1; 
           while(i<len && (i < 0 || p.charAt(0) == '.' || p.charAt(0) == s.charAt(i))){
               if(isMatch(s.substring(i+1), p.substring(2)))
                   return true;
               i++;
           }
       }
           return false;
 }
}



//C代码 :
    bool matchFirst(const char *s, const char *p){
        return (*p == *s || (*p == '.' && *s != '\0'));
    }


bool isMatch(char* s, char* p) {
    if (*p == '\0') return *s == '\0';  //empty


    if (*(p + 1) != '*') {//without *
        if(!matchFirst(s,p)) return false;
        return isMatch(s + 1, p + 1);
    } else { //next: with a *
        if(isMatch(s, p + 2)) return true;    //try the length of 0
        while ( matchFirst(s,p) )       //try all possible lengths 
            if (isMatch(++s, p + 2))
            return true;
        return false;
    }
}


阅读(291) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~