Как получить максимальное значение из коллекции (например, ArrayList)?
Существует ArrayList, который хранит целочисленные значения. Мне нужно найти максимальное значение в этом списке. Например, предположим, что сохраненные значения arrayList: 10, 20, 30, 40, 50
а максимальное значение будет 50
.
Какой эффективный способ найти максимальное значение?
@Ред.: Я только что нашел одно решение, в котором я не очень уверен
ArrayList<Integer> arrayList = new ArrayList<Integer>();
arrayList.add(100); /* add(200), add(250) add(350) add(150) add(450)*/
Integer i = Collections.max(arrayList)
и это возвращает самое высокое значение.
Другой способ сравнить каждое значение, например, selection sort or binary sort algorithm
Ответы
Ответ 1
Вы можете использовать Collections API
чтобы легко достичь желаемого - читать эффективно - достаточно Javadoc для Collections.max
Collections.max(arrayList);
Возвращает максимальный элемент данной коллекции в соответствии с естественным упорядочением ее элементов. Все элементы в коллекции должны реализовывать интерфейс Comparable.
Ответ 2
Этот вопрос почти год назад, но я обнаружил, что если вы создаете собственный компаратор для объектов, вы можете использовать Collections.max для списка объектов массива.
import java.util.Comparator;
public class compPopulation implements Comparator<Country> {
public int compare(Country a, Country b) {
if (a.getPopulation() > b.getPopulation())
return -1; // highest value first
if (a.getPopulation() == b.Population())
return 0;
return 1;
}
}
ArrayList<Country> X = new ArrayList<Country>();
// create some country objects and put in the list
Country ZZ = Collections.max(X, new compPopulation());
Ответ 3
public int getMax(ArrayList list){
int max = Integer.MIN_VALUE;
for(int i=0; i<list.size(); i++){
if(list.get(i) > max){
max = list.get(i);
}
}
return max;
}
По моему мнению, это в основном то, что делает Collections.max(), хотя они используют компаратор, поскольку списки являются общими.
Ответ 4
Мы можем просто использовать метод Collections.max()
и Collections.min()
.
public class MaxList {
public static void main(String[] args) {
List l = new ArrayList();
l.add(1);
l.add(2);
l.add(3);
l.add(4);
l.add(5);
System.out.println(Collections.max(l)); // 5
System.out.println(Collections.min(l)); // 1
}
}
Ответ 5
Comparator.comparing
В Java 8 коллекции были улучшены с помощью лямбды. Таким образом, нахождение max и min может быть выполнено следующим образом, используя Comparator.comparing
:
Код:
List<Integer> ints = Stream.of(12, 72, 54, 83, 51).collect(Collectors.toList());
System.out.println("the list: ");
ints.forEach((i) -> {
System.out.print(i + " ");
});
System.out.println("");
Integer minNumber = ints.stream()
.min(Comparator.comparing(i -> i)).get();
Integer maxNumber = ints.stream()
.max(Comparator.comparing(i -> i)).get();
System.out.println("Min number is " + minNumber);
System.out.println("Max number is " + maxNumber);
Выход:
the list: 12 72 54 83 51
Min number is 12
Max number is 83
Ответ 6
Integer класс реализует Comparable.So мы можем легко получить максимальное или минимальное значение в списке Integer.
public int maxOfNumList() {
List<Integer> numList = new ArrayList<>();
numList.add(1);
numList.add(10);
return Collections.max(numList);
}
Если класс не реализует Comparable, и мы должны найти максимальное и минимальное значение, тогда мы должны написать собственный Компаратор.
List<MyObject> objList = new ArrayList<MyObject>();
objList.add(object1);
objList.add(object2);
objList.add(object3);
MyObject maxObject = Collections.max(objList, new Comparator<MyObject>() {
@Override
public int compare(MyObject o1, MyObject o2) {
if (o1.getValue() == o2.getValue()) {
return 0;
} else if (o1.getValue() > o2.getValue()) {
return -1;
} else if (o1.getValue() < o2.getValue()) {
return 1;
}
return 0;
}
});
Ответ 7
Нет особо эффективного способа найти максимальное значение в несортированном списке - вам просто нужно проверить их все и вернуть максимальное значение.
Ответ 8
Вот еще три способа найти максимальное значение в списке, используя потоки:
List<Integer> nums = Arrays.asList(-1, 2, 1, 7, 3);
Optional<Integer> max1 = nums.stream().reduce(Integer::max);
Optional<Integer> max2 = nums.stream().max(Comparator.naturalOrder());
OptionalInt max3 = nums.stream().mapToInt(p->p).max();
System.out.println("max1: " + max1.get() + ", max2: "
+ max2.get() + ", max3: " + max3.getAsInt());
Все эти методы, подобно Collections.max
, перебирают по всей коллекции, поэтому они требуют времени, пропорционального размеру коллекции.
Ответ 9
Java 8
Поскольку целые числа сравнимы, мы можем использовать следующую строку:
List<Integer> ints = Stream.of(22,44,11,66,33,55).collect(Collectors.toList());
Integer max = ints.stream().mapToInt(i->i).max().orElseThrow(NoSuchElementException::new); //66
Integer min = ints.stream().mapToInt(i->i).min().orElseThrow(NoSuchElementException::new); //11
Еще один момент, на который следует обратить внимание: мы не можем использовать Funtion.identity()
вместо i->i
как mapToInt
ожидает ToIntFunction
которая является совершенно другим интерфейсом и не связана с Function
. Кроме того, в этом интерфейсе есть только один метод applyAsInt
и нет метода identity()
.
Ответ 10
Вот фукнция
public int getIndexOfMax(ArrayList<Integer> arr){
int MaxVal = arr.get(0); // take first as MaxVal
int indexOfMax = -1; //returns -1 if all elements are equal
for (int i = 0; i < arr.size(); i++) {
//if current is less then MaxVal
if(arr.get(i) < MaxVal ){
MaxVal = arr.get(i); // put it in MaxVal
indexOfMax = i; // put index of current Max
}
}
return indexOfMax;
}
Ответ 11
package in.co.largestinarraylist;
import java.util.ArrayList;
import java.util.Scanner;
public class LargestInArrayList {
public static void main(String[] args) {
int n;
ArrayList<Integer> L = new ArrayList<Integer>();
int max;
Scanner in = new Scanner(System.in);
System.out.println("Enter Size of Array List");
n = in.nextInt();
System.out.println("Enter elements in Array List");
for (int i = 0; i < n; i++) {
L.add(in.nextInt());
}
max = L.get(0);
for (int i = 0; i < L.size(); i++) {
if (L.get(i) > max) {
max = L.get(i);
}
}
System.out.println("Max Element: " + max);
in.close();
}
}
Ответ 12
В дополнение к ответу gotomanners, на случай, если кто-нибудь еще придет сюда в поисках абсолютно безопасного решения той же проблемы, я остановился на этом
Collections.max(arrayList, Comparator.nullsFirst(Comparator.naturalOrder()))
Ответ 13
В Java8
arrayList.stream()
.reduce(Integer::max)
.get()
Ответ 14
в зависимости от размера вашего массива многопоточное решение может также ускорить работу