为了账号安全,请及时绑定邮箱和手机立即绑定

java String contains逻辑的优化

java String contains逻辑的优化

桃花长相依 2019-02-20 05:59:06
有一个"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,正则表达式之类的实现。
查看完整描述

2 回答

?
墨色风雨

TA贡献1853条经验 获得超6个赞

LZ可以考虑使用HashSet集合。

查看完整回答
反对 回复 2019-03-01
?
料青山看我应如是

TA贡献1772条经验 获得超8个赞

    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;
    
    
查看完整回答
反对 回复 2019-03-01
  • 2 回答
  • 0 关注
  • 723 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信