Как получить максимальное значение из коллекции (например, 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

в зависимости от размера вашего массива многопоточное решение может также ускорить работу