文档章节

一道笔试题

芝麻糖葫芦
 芝麻糖葫芦
发布于 2017/05/18 21:23
字数 428
阅读 26
收藏 0

下午面试遇到一道笔试题,题目是编写一个支持部分正则表达式的解析器,获取目标字符串在原字符串中第一次出现的索引,例如 查找“ava”在“Lear Java.”中第一次出现的索引为6

其中“.”代表任意单个字符,“^”代表从字符串的开头开始匹配,“$”匹配字符串的结尾,“*”匹配任意个字符

因为在其他笔试题中浪费了太多时间,没有写出这部分代码,回家路上有了思路,现在记录下来。

/**
 * 主要的工具类
 * Created by Morven on 2017/5/18.
 */
public class RegularMacher {
    private RegularMacher() {}

    private static class RegularMacherHolder {
        private static RegularMacher instance = new RegularMacher();
    }

    public static RegularMacher getInstance() {
        return RegularMacherHolder.instance;
    }

    public int matchIndex(String source, String regular) {
        char[] chars = regular.toCharArray();
        for (int i = 0; i < source.length(); i++) {
            int index = indexOf(source, i, chars, 0);
            if (index > -1) return index;
        }
        return -1;
    }

    private int indexOf(String source, int beginIndex, char[] chars, int charIndex) {
        char c = chars[charIndex];
        if (c == '^') {
            if (beginIndex > 0) {
                return -1;
            }
            int index = indexOf(source, beginIndex, chars, charIndex + 1);
            if (index > -1) {
                return beginIndex;
            }
            return -1;
        } else if (c == '$') {
            if (beginIndex < source.length()) {
                return -1;
            }
            return beginIndex;
        } else if (c == '.') {
        } else if (c == '*') {
            if (charIndex + 1 == chars.length) {
                return beginIndex;
            }
            if (charIndex + 2 == chars.length && chars[charIndex + 1] == '$') {
                return beginIndex;
            }
            for (int i = beginIndex; i < source.length(); i++) {
                int index = indexOf(source, i, chars, charIndex + 1);
                if (index > -1) return index;
            }
            return -1;
        } else {
            if (c != source.charAt(beginIndex)) {
                return -1;
            }
        }
        if (charIndex + 1 == chars.length) return beginIndex;
        if (beginIndex + 1 == source.length()) {
            if (charIndex + 2 < chars.length) return -1;
        }
        int index = indexOf(source, beginIndex + 1, chars, charIndex + 1);
        if (index > -1) {
            return beginIndex;
        }
        return -1;
    }
}

/**
 * 测试
 * Created by Morven on 2017/5/18.
 */
public class RegularMacherTest {
    public static void main(String[] args) {
        System.out.println(RegularMacher.getInstance().matchIndex("Test java in Action.", ".est"));//0
        System.out.println(RegularMacher.getInstance().matchIndex("Test java in Action.", ".ssdfa"));//-1
        System.out.println(RegularMacher.getInstance().matchIndex("Test java in Action.", "^.aa"));//-1
        System.out.println(RegularMacher.getInstance().matchIndex("Test java in Action.", "*"));//0
        System.out.println(RegularMacher.getInstance().matchIndex("Test java in Action.", "*$"));//0
        System.out.println(RegularMacher.getInstance().matchIndex("Test java in Action.", "j*i"));//5
        System.out.println(RegularMacher.getInstance().matchIndex("Test java in Action.", "j*ava"));//5
    }
}

© 著作权归作者所有

共有 人打赏支持
芝麻糖葫芦
粉丝 3
博文 20
码字总数 5238
作品 0
济南
高级程序员
私信 提问

暂无文章

OSChina 周二乱弹 —— 以后我偷小鱼干养你

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @庞巴哥 :只有这节奏瞬间变得轻松。。。。。。。。。分享Talking Eyes的单曲《In the sun (Extended Version)》: 《In the sun (Extended Ve...

小小编辑
36分钟前
1
0
多表查询

第1章 多表关系实战 1.1 实战1:省和市  方案1:多张表,一对多  方案2:一张表,自关联一对多 1.2 实战2:用户和角色 (比如演员和扮演人物)  多对多关系 1.3 实战3:角色和权限 (比如...

stars永恒
今天
7
0
求推广,德邦快递坑人!!!!

完全没想好怎么来吐槽自己这次苦逼的德邦物流过程了,只好来记一个流水账。 从寄快递开始: 2019年1月15日从 德邦物流 微信小app上下单,截图如下: 可笑的是什么,我预约的是17号上门收件,...

o0无忧亦无怖
昨天
10
0
Mac Vim配置

1.升级 vim   我自己 MacBook Pro 的系统还是 10.11 ,其自带的 vim 版本为 7.3 ,我们将其升至最新版: 使用 homebrew : brew install vim --with-lua --with-override-system-vim 这将下...

Pasenger
昨天
9
0
vmware安装Ubuntu上不了网?上网了安装不了net-tools,无法执行ifconfig?

1.重新设置网络适配器还是不行,如下指定nat 2.还需要指定共享网络,我是在无线环境下 3.无法执行ifconfig https://packages.ubuntu.com/bionic/net-tools到这个网站下载net-tools的deb文件...

noob_chr
昨天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部