Привет, я принимаю общий счет в двух списках.
Вот мой код.Получение общих пар строк в двух строковых списках
public static int getMatchCount(List<String> listOne, List<String> listTwo) {
String valueOne = "";
String valueTwo = "";
int matchCount = 0;
boolean isMatchedOnce=false;
for (int i = 0; i < listOne.size(); i++) {
valueOne = listOne.get(i);
isMatchedOnce=false;
if (StringUtils.isBlank(valueOne))
continue;
for (int j = 0; j < listTwo.size(); j++) {
valueTwo = listTwo.get(j);
if (StringUtils.isBlank(valueTwo))
continue;
if (valueTwo.equals(valueOne) && (!isMatchedOnce)) {
matchCount++;
listOne.set(i, "");
listTwo.set(j, "");
isMatchedOnce=true;
}
}
}
return matchCount;
}
for ex
listone listTwo
A A
A B
B
Тогда результат 2 не 3
Как их только две общие пары мы можем вынуть.
Но метод очень медленный Любое усовершенствование метода выше, чтобы сделать его быстрым.
Вы хотите подсчитать общие элементы в обоих списках. Я прав? – sgowd