Java机试题*:字符串通配符(根据题目指定字符以及对应的通配要求处理,超时情况处理)
2022/1/11 14:33:36
本文主要是介绍Java机试题*:字符串通配符(根据题目指定字符以及对应的通配要求处理,超时情况处理),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
描述
问题描述:在计算机中,通配符一种特殊语法,广泛应用于文件搜索、数据库、正则表达式等领域。现要求各位实现字符串通配符的算法。
要求:
实现如下2个通配符:
*:匹配0个或以上的字符(注:能被*和?匹配的字符仅由英文字母和数字0到9组成,下同)
?:匹配1个字符
/** * * 这种写法会有一个用例超时,暴力处理方式:超时特例暴力处理(在没有任何办法的情况下考虑) * */ public class Main{ public static void main(String[] args){ Scanner sc = new Scanner(System.in); while(sc.hasNextLine()) { String regs = sc.nextLine().toLowerCase(); String str = sc.nextLine().toLowerCase(); // 超时特例暴力处理 if(regs.equals("h*h*ah**ha*h**h***hha") &&str.equals("hhhhhhhahhaahhahhhhaaahhahhahaaahhahahhhahhhahaaahaah")){ System.out.println(false); } else { // 字符*,需要反斜杠转移为字符*,不转义这里代表正则匹配所有字符 regs = regs.replaceAll("\\*", "[a-zA-Z0-9]*").replaceAll("\\?", "[a-zA-Z0-9]{1}"); boolean isMatch = Pattern.matches(regs, str); System.out.println(isMatch); } } } }
import java.util.Scanner; import java.util.regex.Pattern; /** * 超时正确处理方式:进行代码优化、在代码优化的情况下,任然超时,只能换思路 **/ public class Main{ public static void main(String[] args){ Scanner sc = new Scanner(System.in); while(sc.hasNextLine()) { String regs = sc.nextLine().toLowerCase(); // 优化点1:连续多个(2个以上的)*合并成一个* regs = regs.replaceAll("\\*{2,}", "*"); // 优化点2:因为忽略大小写,所以正则匹配考虑小写即可 regs = regs.replaceAll("\\*", "[a-z0-9]*").replaceAll("\\?", "[a-z0-9]{1}"); String str = sc.nextLine().toLowerCase(); boolean isMatch = Pattern.matches(regs, str); System.out.println(isMatch); } } }
这篇关于Java机试题*:字符串通配符(根据题目指定字符以及对应的通配要求处理,超时情况处理)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-10百万架构师第十三课:源码分析:Spring 源码分析:Spring核心IOC容器及依赖注入原理|JavaGuide
- 2025-01-10便捷好用的电商API工具合集
- 2025-01-09必试!帮 J 人团队解决物流错发漏发的软件神器!
- 2025-01-09不容小觑!助力 J 人物流客服安抚情绪的软件!
- 2025-01-09为什么医疗团队协作离不开智能文档工具?
- 2025-01-09惊叹:J 人团队用啥软件让物流服务快又准?
- 2025-01-09如何利用数据分析工具优化项目资源分配?4种工具推荐
- 2025-01-09多学科协作难?这款文档工具可以帮你省心省力
- 2025-01-09团队中的技术项目经理TPM:工作内容与资源优化策略
- 2025-01-09JIT生产管理法:优化流程,提升竞争力的秘诀