java String contains逻辑的优化
PHP中文网
PHP中文网 2017-04-18 10:50:49
0
4
638

有一个"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,正则表达式之类的实现。

PHP中文网
PHP中文网

认证高级PHP讲师

répondre à tous(4)
洪涛

Facile,Avec 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));
}
小葫芦

LZ peut envisager d'utiliser la collection HashSet.

Peter_Zhu

Pouvez-vous tester si cette expression régulière fonctionne ?

Mais j’ai l’impression que ce n’est pas très bien de devoir épeler une chaîne normale.

迷茫
    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;
    
    
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal