您的位置:首页技术文章
文章详情页

java String contains逻辑的优化

浏览:30日期:2024-01-22 18:01:14

问题描述

有一个'AAA,BBB'格式的字符串组成的List,有一个字符串SSS现在想遍历List,如果字符串SSS中包含了AAA,并且包含了BBB,则返回ture。否则将List全部遍历,都不符合条件则返回false。

目前的思路是在遍历List的时候,使用split分割为String数组:['AAA','BBB'];然后使用contains判断字符串SSS中是否包含'AAA',包含则继续判断SSS是否包含'BBB',符合条件则返回true,不符合条件则继续遍历下一条,直到遍历结束。代码如下:

for(String tab : list){ String listStr[] = tab.split(','); if (sss.contains(listStr[0]) && sss.contains(listStr[1])){return true; }}return false;

但是感觉这种方法效率比较低,请问各位大神有没有什么思路优化一下现在的逻辑?比如使用HashMap,正则表达式之类的实现。

问题解答

回答1:

Easy,With Java 8:

public boolean isContain(List<String> strings, String sss) { return Objects.nonNull(sss)&& (!sss.isEmpty())&& strings.stream().map(s -> s.split(',')).map(Arrays::stream).anyMatch(string -> string.allMatch(sss::contains));}回答2:

LZ可以考虑使用HashSet集合。

回答3:

可以测试下这个正则行不行java String contains逻辑的优化

但是感觉还要拼一个正则字符串也不是太好。

回答4:

boolean flag = flase; String regex='[A]{3}.*[B]{3}';Pattern pattern = Pattern.compile(regex);Matcher matcher = pattern.matcher(SSS);if(matcher.matches()) { flag=ture; } return flag;

标签: java
相关文章: