2013-06-04 4 views
4

У меня есть 2 строки:Как найти отличия от 2 ArrayLists of Strings?

A1=[Rettangolo, Quadrilatero, Rombo, Quadrato] 
A2=[Rettangolo, Rettangolo, Rombo, Quadrato] 

Я хочу, чтобы получить это: «я нашел„четырехугольник“, вместо„Rettangolo“». Если я использую removeAll() или retainAll(), он не работает, потому что у меня есть 2 экземпляра «Rettangolo». На самом деле, если я использую a1.containsAll(a2), я становлюсь истинным, и я хочу false.

Спасибо всем за рассмотрение моей просьбы.

+0

Могут ли массивы различной длины? – fge

+0

Вы хотите, чтобы все элементы в A1 присутствовали в A2 независимо от порядка или порядка, также важного? –

+0

Да размеры массивов могут быть разными. Порядок не важен. –

ответ

5

Используйте метод remove из ArrayList. Он удаляет только первое событие.

public static void main(String []args){ 
     //Create ArrayLists 
     String[] A1 = {"Rettangolo", "Quadrilatero", "Rombo", "Quadrato"}; 
     ArrayList<String> a1=new ArrayList(Arrays.asList(A1)); 
     String[] A2 ={"Rettangolo", "Rettangolo", "Rombo", "Quadrato"}; 
     ArrayList<String> a2=new ArrayList(Arrays.asList(A2)); 
     // Check ArrayLists 
     System.out.println("a1 = " + a1); 
     System.out.println("a2 = " + a2); 
     // Find difference 
     for(String s : a1) 
      a2.remove(s); 
     // Check difference 
     System.out.println("a1 = " + a1); 
     System.out.println("a2 = " + a2); 
} 

Результат

a1 = [Rettangolo, Quadrilatero, Rombo, Quadrato] 
a2 = [Rettangolo, Rettangolo, Rombo, Quadrato] 
a1 = [Rettangolo, Quadrilatero, Rombo, Quadrato] 
a2 = [Rettangolo] 
+0

Я отправлю пример кода, если нужно, как только я его протещу. – AnthonyW

+0

Да, спасибо. Я буду очень благодарен за это, потому что я попытался с помощью метода удаления, повторяющегося в 2 списках, но мне не повезло. –

+0

переключите a1 и a2 в каждом цикле, чтобы получить другой результат. Затем вы можете просто добавить их в свой вывод. – AnthonyW

1

Вот три решения.

Реализация, использующая метод удаления.

public static boolean same(List<String> list1, List<String> list2){ 
    if (list1.size() != list2.size()) 
     return false; 
    List<String> temp = new ArrayList<String>(list1); 
    temp.removeAll(list2); 
    return temp.size() == 0; 
} 

Решение, которое сортирует, затем сравнивает.

public static boolean same(List<String> list1, List<String> list2){ 
    if (list1.size() != list2.size()) 
     return false; 
    Collections.sort(list1); 
    Collections.sort(list2); 
    for (int i=0;i<list1.size();i++){ 
     if (!list1.get(i).equals(list2.get(i))) 
      return false; 
    } 
    return true; 
} 

И, просто для удовольствия, вы можете сделать это, выполнив разницу слов между двумя массивами. Это было бы не самым эффективным, но оно работает и, возможно, может быть полезным.

public static boolean same(List<String> list1, List<String> list2){ 
    Map<String,Integer> counts = new HashMap<String,Integer>(); 
    for (String str : list1){ 
     Integer i = counts.get(str); 
     if (i==null) 
      counts.put(str, 1); 
     else 
      counts.put(str, i+1); 
    } 
    for (String str : list2){ 
     Integer i = counts.get(str); 
     if (i==null) 
      return false; /// found an element that's not in the other 
     else 
      counts.put(str, i-1); 
    } 
    for (Entry<String,Integer> entry : counts.entrySet()){ 
     if (entry.getValue() != 0) 
      return false; 
    } 
    return true; 
} 
+0

Ничего себе, спасибо за подробный ответ! –

0

Это обнаружит пересечение между двумя массивами для данного конкретного случая, которые вы объяснили.

String[] A1 = { "Rettangolo", "Quadrilatero", "Rombo", "Quadrato" }; 
String[] A2 = { "Rettangolo", "Rettangolo", "Rombo", "Quadrato" }; 
ArrayList<String> a1 = new ArrayList<String>(Arrays.asList(A1)); 
ArrayList<String> a2 = new ArrayList<String>(Arrays.asList(A2)); 
a1.removeAll(a2); 
System.out.println("I have found " + a1); 
0

Я надеюсь, что это поможет вам

String[] A1 = {"Rettangolo", "Quadrilatero", "Rombo", "Quadrato"}; 
    String[] A2 ={"Rettangolo", "Rettangolo", "Rombo", "Quadrato"}; 

    Set<String> set1 = new HashSet<String>(); 
    Set<String> set2 = new HashSet<String>(); 

    set1.addAll(Arrays.asList(A1)); 
    set2.addAll(Arrays.asList(A2)); 

    set1.removeAll(set2); 
    System.out.println(set1);// ==> [Quadrilatero] 
2

Эти два класса может помочь. Дайте мне знать, как я могу улучшить это дальше. Не стесняйтесь использовать приведенный ниже код в своей собственной работе. Я должен указать, что текущий код не заботится о повторных элементах списка.

import java.util.List; 

public class ListDiff<T> { 

    private List<T> removed; 
    private List<T> added; 

    public ListDiff(List<T> removed, List<T> added) { 
     super(); 
     this.removed = removed; 
     this.added = added; 
    } 

    public ListDiff() { 
     super(); 
    } 

    public List<T> getRemoved() { 
     return removed; 
    } 

    public List<T> getAdded() { 
     return added; 
    } 

} 

Полезный класс.

import java.util.ArrayList; 
import java.util.Arrays; 
import java.util.Comparator; 
import java.util.List; 

public class ListUtil { 

    public static <T> ListDiff<T> diff(List<T> one, List<T> two) { 

     List<T> removed = new ArrayList<T>(); 
     List<T> added = new ArrayList<T>(); 

     for (int i = 0; i < one.size(); i++) { 
      T elementOne = one.get(i); 
      if (!two.contains(elementOne)) { 
       //element in one is removed from two 
       removed.add(elementOne); 
      } 
     } 

     for (int i = 0; i < two.size(); i++) { 
      T elementTwo = two.get(i); 
      if (!one.contains(elementTwo)) { 
       //element in two is added. 
       added.add(elementTwo); 
      } 
     } 

     return new ListDiff<T>(removed, added); 
    } 

    public static <T> ListDiff<T> diff(List<T> one, List<T> two, Comparator<T> comparator) { 
     List<T> removed = new ArrayList<T>(); 
     List<T> added = new ArrayList<T>(); 

     for (int i = 0; i < one.size(); i++) { 
      T elementOne = one.get(i); 
      boolean found = false; 

      //loop checks if element in one is found in two. 
      for (int j = 0; j < two.size(); j++) { 
       T elementTwo = two.get(j); 
       if (comparator.compare(elementOne, elementTwo) == 0) { 
        found = true; 
        break; 
       } 
      } 
      if (found == false) { 
       //element is not found in list two. it is removed. 
       removed.add(elementOne); 
      } 
     } 

     for (int i = 0; i < two.size(); i++) { 
      T elementTwo = two.get(i); 
      boolean found = false; 

      //loop checks if element in two is found in one. 
      for (int j = 0; j < one.size(); j++) { 
       T elementOne = one.get(j); 
       if (comparator.compare(elementTwo, elementOne) == 0) { 
        found = true; 
        break; 
       } 
      } 
      if (found == false) { 
       //it means element has been added to list two. 
       added.add(elementTwo); 
      } 

     } 

     return new ListDiff<T>(removed, added); 
    } 

    public static void main(String args[]) { 
     String[] arr1 = { "london", "newyork", "delhi", "singapore", "tokyo", "amsterdam" }; 
     String[] arr2 = { "london", "newyork", "delhi", "singapore", "seoul", "bangalore", "oslo" }; 

     ListDiff<String> ld = ListUtil.diff(Arrays.asList(arr1), Arrays.asList(arr2)); 
     System.out.println(ld.getRemoved()); 
     System.out.println(ld.getAdded()); 

     ld = ListUtil.diff(Arrays.asList(arr1), Arrays.asList(arr2), new Comparator<String>() { 
      public int compare(String o1, String o2) { 
       return o1.compareTo(o2); 
      } 
     }); //sample for using custom comparator 
     System.out.println(ld.getRemoved()); 
     System.out.println(ld.getAdded()); 
    } 
}