Obtener la diferencia entre dos ArrayList con elementos duplicados

mido:

Quiero obtener la diferencia entre dos listas. Y esto es lo que estoy haciendo.

oldList = [1,1,2,2,3,3,4,4]
newList = [1,2,3,5]

List<Integer> add = new ArrayList<>(newList);
List<Integer> remove = new ArrayList<>(oldList);
add.removeAll(oldList);
remove.removeAll(newList);

El resultado que quiero

add = [5]
remove = [1,2,3,4,4]

Pero removeAll()eliminar todo elemento duplicado. Los resultados que he recibido

add = [5]
remove = [4,4]

¿Cómo consigo el addy removelista? Gracias.

Algún chico :

Vas a tener que escribir algo de su propio código. Esto no se puede hacer utilizando sólo las bibliotecas de Java Collection solos.

import java.util.ArrayList;

public class MyList<T> extends ArrayList<T>{

    public MyList(){
        super();
    }

    public void specialRemoveAll(T[] list) {
        for (T element : list) {
            remove(element); // This only removes the first entry that matches 'element', not all matches
        }
    }

}

Supongo que te gusta

Origin http://10.200.1.11:23101/article/api/json?id=400887&siteId=1
Recomendado
Clasificación