Удалить, который мы использовали для однократного удаления, но я хочу удалить несколько значений в массиве List.
ArrayList<Integer> al=new ArrayList<Integer>();
al.add(7);
al.add(8);
al.add(9);
al.add(13);
al.add(22);
al.add(55);
al.add(88);
//adding values
for(int i=0;i<100;i++){
al.add(i);
}
Я добавил повторяющиеся элементы, я хочу получить повторяющиеся элементы и удалить их из Arraylist
Например:
вывод как: 1, 2, 3, 4, 5, 6, 10, 11, 12, 14, 15, 16, 17, 18, 19, 20, 21, 23, 24, 25, 26, 27, 28, 29 , 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54 , 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80 , 81, 82, 83, 84, 85, 86, 87, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100
да, но мне нужны повторяющиеся элементы. что элементы отсутствуют в моем выводе
Зачем ты это делаешь? (т.е. какова общая картина) и всегда ли вы будете знать, какой диапазон вам нужен? (т.е. от 1 до 100)
Возможный дубликат stackoverflow.com/questions/203984/…
@ shanbhagsv я не получил ответа, поэтому спросил здесь




Используйте потоки, чтобы получить отличную ценность. Однако я все еще считаю, что наборы идеально подходят для этого сценария.
ArrayList<Integer> al=new ArrayList<Integer>();
al.add(7);
al.add(8);
al.add(9);
al.add(13);
al.add(22);
al.add(55);
al.add(88);
List<Integer> list = al.stream().distinct().collect(Collectors.toList());
System.out.println(list);
ArrayList<Integer> withoutDuplicates = new ArrayList<>(new HashSet<>(al));
Не влияет на исходный список с дубликатами, о чем вы, кажется, и просите. Если вам не важна структура, используемая для второй коллекции, вы можете просто сохранить ее как Set, не создавая другой ArrayList.
«Я хочу получить повторяющиеся элементы и удалить их из Arraylist» -> Я запутался, вы просили удалить повторяющиеся элементы, вы имели в виду удалить ОБЕ значения, если существует более одного для данного числа?
Используйте два ArrayList, один с объектами для удаления и используйте removeAll метод:
Removes from this list all of its elements that are contained in the specified collection.
ArrayList<Integer> toRemove=new ArrayList<>();//use diamond operator to reduce verbosity
toRemove.add(7);
toRemove.add(8);
toRemove.add(9);
toRemove.add(13);
toRemove.add(22);
toRemove.add(55);
toRemove.add(88);
ArrayList<Integer> al=new ArrayList<>();
for(int i=0;i<100;i++){
al.add(i);
}
al.removeAll(toRemove);
Вы можете вкратце объяснить
@Venkatesh добавил больше деталей, один список содержит объекты для удаления, а полный список удаляет все объекты с помощью метода removeAll
@ user7294900 Спасибо
@venkat, вы можете принять ответ, если он окажется наиболее полезным. см. stackoverflow.com/help/someone-answers
ArrayList<Integer> al=new ArrayList<Integer>();
ArrayList<Integer> remove=new ArrayList<Integer>();
al.add(7);
al.add(8);
al.add(9);
al.add(13);
al.add(22);
al.add(55);
al.add(88);
remove.add(7);
remove.add(8);
remove.add(9);
remove.add(13);
remove.add(22);
remove.add(55);
remove.add(88);
//adding values
for(int i=0;i<100;i++){
al.add(i);
}
al.removeAll(remove);
System.out.println(al);
Если вам не нужны дубликаты, почему бы не использовать
Set?