有一個"AAA,BBB"格式的字符串組成的List,有一個字符串SSS現(xiàn)在想遍歷List,如果字符串SSS中包含了AAA,并且包含了BBB,則返回ture。否則將List全部遍歷,都不符合條件則返回false。
目前的思路是在遍歷List的時候,使用split分割為String數(shù)組:["AAA","BBB"];然后使用contains判斷字符串SSS中是否包含"AAA",包含則繼續(xù)判斷SSS是否包含"BBB",符合條件則返回true,不符合條件則繼續(xù)遍歷下一條,直到遍歷結(jié)束。代碼如下:
for(String tab : list){
String listStr[] = tab.split(",");
if (sss.contains(listStr[0]) && sss.contains(listStr[1])){
return true;
}
}
return false;
但是感覺這種方法效率比較低,請問各位大神有沒有什么思路優(yōu)化一下現(xiàn)在的邏輯?比如使用HashMap,正則表達式之類的實現(xiàn)。
2 回答

料青山看我應(yīng)如是
TA貢獻1772條經(jīng)驗 獲得超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;
添加回答
舉報
0/150
提交
取消