Структура коллекций определяет несколько алгоритмов, которые могут применяться к коллекциям и Map.
Эти алгоритмы определяются как статические методы в классе Collections. Некоторые из методов могут генерировать ClassCastException, которое возникает при попытке сравнить несовместимые типы или UnsupportedOperationException, которое возникает, когда предпринимается попытка изменить немодифицируемую коллекцию.
Методы
Методы, определенные в алгоритме структуры коллекции, суммированы в следующей таблице:
№ | Метод и описание |
1 | static int binarySearch(List list, Object value, Comparator c) Ищет значение в списке, упорядоченном согласно c. Возвращает позицию значения в списке или -1, если значение не найдено. |
2 | static int binarySearch(List list, Object value) Ищет значение в списке. Список должен быть отсортирован. Возвращает позицию значения в списке или -1, если значение не найдено. |
3 | static void copy(List list1, List list2) Копирует элементы из list2 в list1. |
4 | static Enumeration enumeration(Collection c) Возвращает перечисление по c. |
5 | static void fill(List list, Object obj) Назначает obj каждому элементу списка. |
6 | static int indexOfSubList(List list, List subList) Ищет список для первого появления subList. Возвращает индекс первого совпадения или .1, если совпадение не найдено. |
7 | static int lastIndexOfSubList(List list, List subList) Ищет список для последнего появления subList. Возвращает индекс первого совпадения или .1, если совпадение не найдено. |
8 | static ArrayList list(Enumeration enum) Возвращает ArrayList, содержащий элементы enum. |
9 | static Object max(Collection c, Comparator comp) Возвращает максимальный элемент в c, определенный comp. |
10 | static Object max(Collection c) Возвращает максимальный элемент в c, определенный естественным упорядочением. Сбор не нужно сортировать. |
11 | static Object min(Collection c, Comparator comp) Возвращает минимальный элемент в c, определенный comp. Сбор не нужно сортировать. |
12 | static Object min(Collection c) Возвращает минимальный элемент в c, определенный естественным упорядочением. |
13 | static List nCopies(int num, Object obj) Возвращает num копий obj, содержащихся в неизменяемом списке. num должно быть больше или равно нулю. |
14 | static boolean replaceAll(List list, Object old, Object new) Заменяет все вхождения старых новыми в списке. Возвращает true, если произошла хотя бы одна замена. В противном случае возвращает false. |
15 | static void reverse(List list) Делает порядок в списке задом наперёд. |
16 | static Comparator reverseOrder( ) Возвращает обратный компаратор. |
17 | static void rotate(List list, int n) Поворачивает список по n местам вправо. Для поворота влево используйте отрицательное значение для n. |
18 | static void shuffle(List list, Random r) Перемешивает (т.е. рандомизирует) элементы в списке, используя r как источник случайных чисел. |
19 | static void shuffle(List list) Перемешивает (т.е. рандомизирует) элементы в списке. |
20 | static Set singleton(Object obj) Возвращает obj как неизменяемое множество. Это простой способ преобразования одного объекта в набор. |
21 | static List singletonList(Object obj) Возвращает obj как непреложный список. Это простой способ преобразования одного объекта в список. |
22 | static Map singletonMap(Object k, Object v) Возвращает пару ключ/значение k/v как неизменяемую карту. Это простой способ преобразовать одну пару ключ/значение в карту. |
23 | static void sort(List list, Comparator comp) Сортирует элементы списка, как определено comp. |
24 | static void sort(List list) Сортирует элементы списка, определяемые их естественным упорядочением. |
25 | static void swap(List list, int idx1, int idx2) Обменивает элементы в списке по индексам, указанными idx1 и idx2. |
26 | static Collection synchronizedCollection(Collection c) Возвращает потокобезопасную коллекцию, поддерживаемую c. |
27 | static List synchronizedList(List list) Возвращает список потоков, поддерживаемый списком. |
28 | static Map synchronizedMap(Map m) Возвращает потокобезопасный Map, поддерживаемую m. |
29 | static Set synchronizedSet(Set s) Возвращает потокобезопасный набор, поддерживаемый s. |
30 | static SortedMap synchronizedSortedMap(SortedMap sm) Возвращает потокобезопасный отсортированный Map, поддерживаемый sm. |
31 | static SortedSet synchronizedSortedSet(SortedSet ss) Возвращает потокобезопасный отсортированный набор, поддерживаемый ss. |
32 | static Collection unmodifiableCollection(Collection c) Возвращает немодифицируемую коллекцию, поддерживаемую c. |
33 | static List unmodifiableList(List list) Возвращает немодифицируемый список, поддерживаемый list. |
34 | static Map unmodifiableMap(Map m) Возвращает немодифицируемый Map, поддерживаемую m. |
35 | static Set unmodifiableSet(Set s) Возвращает немодифицируемый набор, поддерживаемый s. |
36 | static SortedMap unmodifiableSortedMap(SortedMap sm) Возвращает немодифицируемый отсортированный Map, поддерживаемый sm. |
37 | static SortedSet unmodifiableSortedSet(SortedSet ss) Возвращает немодифицируемый отсортированный набор, поддерживаемый ss. |
Пример
Ниже приведен пример, демонстрирующий различные алгоритмы в Java:
import java.util.*;
public class AlgorithmsDemo {
public static void main(String args[]) {
// Создаём и инициализируем связанный список
LinkedList ll = new LinkedList();
ll.add(new Integer(-8));
ll.add(new Integer(20));
ll.add(new Integer(-20));
ll.add(new Integer(8));
// Создаём компаратор обратного порядка
Comparator r = Collections.reverseOrder();
// Сортировка списка с помощью компаратора
Collections.sort(ll, r);
// Получаем итератор
Iterator li = ll.iterator();
System.out.print("Список, отсортированный задом наперёд: ");
while(li.hasNext()) {
System.out.print(li.next() + " ");
}
System.out.println();
Collections.shuffle(ll);
// Отображаем случайный список
li = ll.iterator();
System.out.print("Список перемешанный: ");
while(li.hasNext()) {
System.out.print(li.next() + " ");
}
System.out.println();
System.out.println("Минимум: " + Collections.min(ll));
System.out.println("Максимум: " + Collections.max(ll));
}
}
Получим следующий результат:
Список, отсортированный задом наперёд: 20 8 -8 -20
Список перемешанный: 20 -20 8 -8
Минимум: -20
Максимум: 20
Источник: Java - The Collection Algorithms.
Оглавление
- 1. Java – Самоучитель для начинающих
- 2. Java – Обзор языка
- 3. Java – Установка и настройка
- 4. Java – Синтаксис
- 5. Java – Классы и объекты
- 6. Java – Конструкторы
- 7. Java – Типы данных и литералы
- 8. Java – Типы переменных
- 9. Java – Модификаторы
- 10. Java – Операторы
- 11. Java – Циклы и операторы цикла
- 11.1. Java – Цикл while
- 11.2. Java – Цикл for
- 11.3. Java – Улучшенный цикл for
- 11.4. Java – Цикл do..while
- 11.5. Java – Оператор break
- 11.6. Java – Оператор continue
- 12. Java – Операторы принятия решений
- 12.1. Java – Оператор if
- 12.2. Java – Оператор if..else
- 12.3. Java – Вложенный оператор if
- 12.4. Java – Оператор switch..case
- 12.5. Java – Условный оператор (? :)
- 13. Java – Числа
- 13.1. Java – Методы byteValue(), shortValue(), intValue(), longValue(), floatValue(), doubleValue()
- 13.2. Java – Метод compareTo()
- 13.3. Java – Метод equals()
- 13.4. Java – Метод valueOf()
- 13.5. Java – Метод toString()
- 13.6. Java – Метод parseInt()
- 13.7. Java – Метод Math.abs()
- 13.8. Java – Метод Math.ceil()
- 13.9. Java – Метод Math.floor()
- 13.10. Java – Метод Math.rint()
- 13.11. Java – Метод Math.round()
- 13.12. Java – Метод Math.min()
- 13.13. Java – Метод Math.max()
- 13.14. Java – Метод Math.exp()
- 13.15. Java – Метод Math.log()
- 13.16. Java – Метод Math.pow()
- 13.17. Java – Метод Math.sqrt()
- 13.18. Java – Метод Math.sin()
- 13.19. Java – Метод Math.cos()
- 13.20. Java – Метод Math.tan()
- 13.21. Java – Метод Math.asin()
- 13.22. Java – Метод Math.acos()
- 13.23. Java – Метод Math.atan()
- 13.24. Java – Метод Math.atan2()
- 13.25. Java – Метод Math.toDegrees()
- 13.26. Java – Метод Math.toRadians()
- 13.27. Java – Метод Math.random()
- 14. Java – Символы
- 14.1. Java – Метод Character.isLetter()
- 14.2. Java – Метод Character.isDigit()
- 14.3. Java – Метод Character.isWhitespace()
- 14.4. Java – Метод Character.isUpperCase()
- 14.5. Java – Метод Character.isLowerCase()
- 14.6. Java – Метод Character.toUpperCase()
- 14.7. Java – Метод Character.toLowerCase()
- 14.8. Java – Метод Character.toString()
- 15. Java – Строки
- 15.1. Java – Метод charAt()
- 15.2. Java – Метод compareTo()
- 15.3. Java – Метод compareToIgnoreCase()
- 15.4. Java – Метод concat()
- 15.5. Java – Метод contentEquals()
- 15.6. Java – Метод copyValueOf()
- 15.7. Java – Метод endsWith()
- 15.8. Java – Метод equals()
- 15.9. Java – Метод equalsIgnoreCase()
- 15.10. Java – Метод getBytes()
- 15.11. Java – Метод getChars()
- 15.12. Java – Метод hashCode()
- 15.13. Java – Метод indexOf()
- 15.14. Java – Метод intern()
- 15.15. Java – Метод lastIndexOf()
- 15.16. Java – Метод length()
- 15.17. Java – Метод matches()
- 15.18. Java – Метод regionMatches()
- 15.19. Java – Метод replace()
- 15.20. Java – Метод replaceAll()
- 15.21. Java – Метод replaceFirst()
- 15.22. Java – Метод split()
- 15.23. Java – Метод startsWith()
- 15.24. Java – Метод subSequence()
- 15.25. Java – Метод substring()
- 15.26. Java – Метод toCharArray()
- 15.27. Java – Метод toLowerCase()
- 15.28. Java – Метод toString()
- 15.29. Java – Метод toUpperCase()
- 15.30. Java – Метод trim()
- 15.31. Java – Метод valueOf()
- 15.32. Java – Классы StringBuilder и StringBuffer
- 15.32.1. Java – Метод append()
- 15.32.2. Java – Метод reverse()
- 15.32.3. Java – Метод delete()
- 15.32.4. Java – Метод insert()
- 15.32.5. Java – Метод replace()
- 16. Java – Массивы
- 17. Java – Дата и время
- 18. Java – Регулярные выражения
- 19. Java – Методы
- 20. Java – Потоки ввода/вывода, файлы и каталоги
- 20.1. Java – Класс ByteArrayInputStream
- 20.2. Java – Класс DataInputStream
- 20.3. Java – Класс ByteArrayOutputStream
- 20.4. Java – Класс DataOutputStream
- 20.5. Java – Класс File
- 20.6. Java – Класс FileReader
- 20.7. Java – Класс FileWriter
- 21. Java – Исключения
- 21.1. Java – Встроенные исключения
- 22. Java – Вложенные и внутренние классы
- 23. Java – Наследование
- 24. Java – Переопределение
- 25. Java – Полиморфизм
- 26. Java – Абстракция
- 27. Java – Инкапсуляция
- 28. Java – Интерфейсы
- 29. Java – Пакеты
- 30. Java – Структуры данных
- 30.1. Java – Интерфейс Enumeration
- 30.2. Java – Класс BitSet
- 30.3. Java – Класс Vector
- 30.4. Java – Класс Stack
- 30.5. Java – Класс Dictionary
- 30.6. Java – Класс Hashtable
- 30.7. Java – Класс Properties
- 31. Java – Коллекции
- 31.1. Java – Интерфейс Collection
- 31.2. Java – Интерфейс List
- 31.3. Java – Интерфейс Set
- 31.4. Java – Интерфейс SortedSet
- 31.5. Java – Интерфейс Map
- 31.6. Java – Интерфейс Map.Entry
- 31.7. Java – Интерфейс SortedMap
- 31.8. Java – Класс LinkedList
- 31.9. Java – Класс ArrayList
- 31.10. Java – Класс HashSet
- 31.11. Java – Класс LinkedHashSet
- 31.12. Java – Класс TreeSet
- 31.13. Java – Класс HashMap
- 31.14. Java – Класс TreeMap
- 31.15. Java – Класс WeakHashMap
- 31.16. Java – Класс LinkedHashMap
- 31.17. Java – Класс IdentityHashMap
- 31.18. Java – Алгоритмы Collection
- 31.19. Java – Iterator и ListIterator
- 31.20. Java – Comparator
- 32. Java – Дженерики
- 33. Java – Сериализация
- 34. Java – Сеть
- 34.1. Java – Обработка URL
- 35. Java – Отправка Email
- 36. Java – Многопоточность
- 36.1. Java – Синхронизация потоков
- 36.2. Java – Межпоточная связь
- 36.3. Java – Взаимная блокировка потоков
- 36.4. Java – Управление потоками
- 37. Java – Основы работы с апплетами
- 38. Java – Javadoc