Как найти запись с максимальным элементом

Improve Article

Save Article

Like Article

  • Read
  • Discuss
  • Improve Article

    Save Article

    Like Article

    Given a map in Java, the task is to find out the entry in this map with the highest value. 

    Illustration: 

    Input  : Map = {ABC = 10, DEF = 30, XYZ = 20}
    Output : DEF = 30
    Input  : Map = {1 = 40, 2 = 30, 3 = 60}
    Output : 3 = 60

    Methods: There can be several approaches to achieve the goal that are listed as follows: 

    1. Simple iterative approach via for each loop
    2. Using max() method from Collections class
    3. Using the concept of Streams introduced in Java 8

    Now we will discuss the above-proposed methods alongside procedure and implementing them via clean java programs.

    Method 1: Using iterative approach for each loop

    Approach:

    1. Iterate the map entry by entry
    2. Store the first entry in a reference variable to compare to initially.
    3. If the current entry’s value is greater than the reference entry’s value, then store the current entry as the reference entry.
    4. Repeat this process for all the entries in the map.
    5. In the end, the reference variable has the required entry with the highest value in the map.
    6. Print this entry
    for (Map.Entry entry : map.entrySet()) 
    { // Operations }

    Example:

    Java

    import java.util.*;

    class GFG {

        public static <K, V extends Comparable<V> >

            Map.Entry<K, V>

            getMaxEntryInMapBasedOnValue(Map<K, V> map)

        {

            Map.Entry<K, V> entryWithMaxValue = null;

            for (Map.Entry<K, V> currentEntry :

                 map.entrySet()) {

                if (

                    entryWithMaxValue == null

                    || currentEntry.getValue().compareTo(

                           entryWithMaxValue.getValue())

                           > 0) {

                    entryWithMaxValue = currentEntry;

                }

            }

            return entryWithMaxValue;

        }

        public static void print(Map<String, Integer> map)

        {

            System.out.print("Map: ");

            if (map.isEmpty()) {

                System.out.println("[]");

            }

            else {

                System.out.println(map);

            }

        }

        public static void main(String[] args)

        {

            Map<String, Integer> map = new HashMap<>();

            map.put("ABC", 10);

            map.put("DEF", 30);

            map.put("XYZ", 20);

            print(map);

            System.out.println(

                "Entry with highest value: "

                + getMaxEntryInMapBasedOnValue(map));

        }

    }

    Output:

    Map: {ABC=10, DEF=30, XYZ=20}
    Entry with highest value: DEF=30

    Method 2: Using max() method from Collections class without lambda expression 

    Example:

    Java

    import java.util.*;

    class GFG {

        public static void main(String[] args)

        {

            HashMap<Integer, Integer> map

                = new HashMap<Integer, Integer>();

            map.put(1, 4);

            map.put(2, 5);

            map.put(3, 7);

            map.put(4, 2);

            int maxValueInMap = (Collections.max(map.values()));

            for (Entry<Integer, Integer> entry :

                 map.entrySet()) {

                if (entry.getValue() == maxValueInMap) {

                    System.out.println(entry.getKey());

                }

            }

        }

    }

    Output:

    3

     Method 3: Using the concept of Streams introduced in Java 8

    Java

    import java.util.stream.*;

    class GFG {

        public static void main(String[] args)

        {

            Map<String, String> map = new HashMap<>();

            map.put("A", "23");

            map.put("F", "43");

            map.put("C", "56");

            map.put("Z", "04");

            System.out.print(map.maxUsingStreamAndLambda());

        }

        public <String, String>

            extends Comparable<String> > maxUsingStreamAndLambda(

                        Map<String, String> map)

        {

            Map<String, String> maxEntry

                = map.entrySet().stream().max(

                    (String e1, String e2)

                        -> e1.getValue().compareTo(

                            0e2.getValue()));

            return maxEntry.get().getValue();

        }

    }

    Output:

    C

    Last Updated :
    13 Sep, 2021

    Like Article

    Save Article

    Дано, таблица:

    table test  
    id:integer  
    x:integer  
    y:integer   
    

    Данные в таблице

    x y  
    1 3  
    2 4  
    3 2  
    4 5  
    

    Задача:
    найти такой X, для которого Y имеет максимальное значение, без подзапросов, order by и view.
    Т.е. в нашем примере максимальный «у»=5 значит нужно в итоге выбрать «х»=4.
    Может как-то можно использовать JOIN с этой же таблицей?

    Dmitriy's user avatar

    Dmitriy

    2,7186 золотых знаков15 серебряных знаков25 бронзовых знаков

    задан 20 дек 2018 в 6:59

    Вадим's user avatar

    4

    Это можно сделать запросом следующего вида:

    SELECT x FROM test WHERE y = (SELECT MAX(y) FROM test) ;
    

    В PostgreSQL точно работает.

    ответ дан 20 дек 2018 в 7:49

    amiranys's user avatar

    amiranysamiranys

    7806 серебряных знаков16 бронзовых знаков

    1

    В оракле (если у вас вдруг он) это можно сделать и без джойнов:

    with t as (select 1 x, 3 y from dual union all
               select 2, 4 from dual union all
               select 3, 2 from dual union all
               select 4, 5 from dual)
    select max(x) keep (dense_rank last order by y)
      from t;
    

    Документация.

    ответ дан 20 дек 2018 в 11:22

    Dmitriy's user avatar

    DmitriyDmitriy

    2,7186 золотых знаков15 серебряных знаков25 бронзовых знаков

    3

    Спасибо Akina.
    В итоге получилось решение.

    SELECT t1.x   
    FROM test t1   
    LEFT JOIN test t2 ON t1.y<t2.y   
    WHERE t2.y IS null;  
    

    Dmitriy's user avatar

    Dmitriy

    2,7186 золотых знаков15 серебряных знаков25 бронзовых знаков

    ответ дан 20 дек 2018 в 10:44

    Вадим's user avatar

    ВадимВадим

    11 серебряный знак3 бронзовых знака

    Есть в базе 2 таблицы — users с полями id и name
    и User_log с полями user_id и login_time.

    Нужен запрос, который даст выборку с полями user_name, last_login (это login_time последней авторизации пользователя). Если в USER_LOGINS нет информации об авторизациях пользователя, значение должно быть пустым.

    Мой вариант выдает одну запись, просто с самым последним login_time, а не у каждого пользователя.
    SELECT users.id, MAX(User_log.login_time) AS user_name, last_login FROM users, user_log WHERE users.id = user_log.user_id
    Помогите, пожалуйста!

    UPD сделал!
    Вот верный ответ:
    SELECT users.Name AS user_name, user_logins.Login_time AS last_login
    FROM users
    LEFT OUTER JOIN
    user_logins
    ON users.ID = user_logins.User_id
    WHERE
    user_logins.Login_time IN
    (SELECT MAX(Login_time) FROM user_logins WHERE users.ID = user_logins.User_id) OR user_logins.Login_time IS NULL;

    Помогло это

    Максимальный и минимальныйЗадачи по нахождению минимального и/или максимального элемента в массиве очень часто встречаются в различных учебных пособиях по программированию и, как правило, вызывают трудности у начинающих программистов или просто студентов, получивших такое задание.

    В данной статье вы узнаете, как написать реализацию программы на языке C++, которая находит максимальный и минимальный элемент в массиве и выводит на экран. А узнать множество решений других задач можно в разделе с решениями задач по программированию на языке C++.

    Что такое максимальный и минимальный элемент массива

    Для начала поймем, что же такое максимальный или минимальный элемент в массиве? Всё просто, максимальный элемент массива — это элемент, который имеет самое большое числовое значение, а минимальный элемент массива — это элемент, имеющий самое маленькое значение.

    Пример: в массиве, состоящем из таких элементов: 3, 1, 0, -4, 16, 2 — максимальный элемент равен 16, т.к. это число больше других, а минимальный элемент равен -4, т.к. оно меньше остальных.

    Поняв это, можно приступить к решению задачи.

    Алгоритм решения задачи

    — Инициализация массива, переменных, хранящих минимальное и максимальное значение.

    — Заполнение массива случайными числами при помощи цикла и функции, возвращающей случайные числа.

    — Вывод массива.

    — Сравнение каждого элемента массива: Если элемент больше переменной с максимальным значением, то значение записывается в переменную; Если элемент меньше переменной с минимальным значением, то значение записывается в переменную.

    — Вывод переменных с максимальным и минимальным элементом.

    Алгоритм решения на языке C++

    Для начала нужно подключить заголовок ввода/вывода <iostream>, заголовок стандартных функций <cstdlib> в ней имеется функция rand(), которая позволит заполнить массив случайными числами. Заполнение каждого элемента массива вручную требует времени, его можно сэкономить автоматизировав процесс. Подключаем пространство имён std. Создаём константу N, она будет определять количество элементов в массиве.

    #include <iostream> 
    #include <cstdlib> 
    
    using namespace std; //Пространство имён std
    
    const int N = 10;//Количество элементов в массиве
    
    int main() 
    {
    
    	return 0;
    }

    В теле функции main() инициализируем массив целых чисел из N лементов, целочисленные переменные max и min, они будут хранить значение максимального и минимального элементов массива соответственно.

    	int mass[N], max, min;

    Теперь заполним массив случайными числами. Для этого используем цикл от 0 до N (не включительно), который пройдется по каждому элементу массива и поместит случайное значение от 0 до 98. Это можно сделать, использовав функцию rand(), которая возвращает случайное число. Поделить возвращаемое значение на 99 и внести в ячейку остаток от деления, таким образом значение ячейки будет иметь значение в диапазоне от 0 до 99(не включая 99, т.к. остаток от деления не может быть кратным делителю).  При этом выведем значения элементов массива на экран.

    	cout << "Элементы: |";
    	for(int r = 0; r<N; r++) // Цикл от 0 до N
    	{
    		mass[r] = rand()%99; // Заполнение случайным числом
    		cout << mass[r] << "|"; // Вывод значения
    	}
    	cout << endl;

    В результате программа выведет на экран значения элементов массива, разделенное вертикальными чертами:

    Элементы: |28|43|72|79|23|70|55|39|69|1|

    Обратите внимание! Если вы программируете под Windows и у Вас не отображаются русские символы в консоли, то советую Вам почитать о решении этой проблемы в статье Русские символы(буквы) при вводе/выводе в консоль на C++.

    Далее определим максимальный и минимальный элемент в массиве, для этого вновь пройдемся по массиву циклом. При помощи условия определим максимальный и минимальный элемент массива.

    Перед циклом нужно будет занести первый элемент массива в переменные min и max, они будут хранить минимальное и максимальное значение изначально, а во время цикла поменяют его, если найдётся значение меньше для min или больше для max.

    	max = mass[0];//Помещаем значения 1-го элемента
    	min = mass[0];//массива в переменные
    	for(int r = 1; r<N; r++)
    	{
    		if(max < mass[r]) max = mass[r]; //если значение элемента больше значения переменной max, то записываем это значение в переменную
    		if(min > mass[r]) min = mass[r]; //аналогично и для min
    	}

    После цикла выведем значения min и max.

    	cout << "Min: " << min << endl;
    	cout << "Max: " << max << endl;

    После компиляции и запуска прогамма выводит следующее

    Элементы: |28|43|72|79|23|70|55|39|69|1|
    Min: 1
    Max: 79
    

    Пробегаемся по элементам массива глазами и видим, что минимальное значение — 1, а максимальное — 79. Переменные min и max имеют эти же значения соответственно, следовательно алгоритм работает.

    Весь листинг программы на C++

    #include <iostream>
    #include <cstdlib>
    
    using namespace std;
    
    const int N = 10;
    
    int main() 
    {
    	int mass[N], max, min;
    
    	cout << "Элементы: |";
    	for(int r = 0; r<N; r++)
    	{
    		mass[r] = rand()%99;
    		cout << mass[r] << "|";
    	}
    	cout << endl;
    	
    	max = mass[0];
    	min = mass[0];
    	for(int r = 1; r<N; r++)
    	{
    		if(max < mass[r]) max = mass[r];
    		if(min > mass[r]) min = mass[r];
    	}
    	cout << "Min: " << min << endl;
    	cout << "Max: " << max << endl;
    	
    	return 0;
    }
    

    В этом посте будет обсуждаться, как найти максимальный элемент из списка целых чисел, используя поток в Java.

    1. Преобразование в IntStream

    Идея состоит в том, чтобы преобразовать список в IntStream и использовать max() метод, предоставленный IntStream который возвращает OptionalInt содержащий максимальный элемент потока. Чтобы развернуть OptionalInt и получить настоящий Integer внутри, мы можем либо использовать orElseThrow или же orElse или же orElseGet.

    // Метод поиска максимального элемента из списка целых чисел в Java 8 и выше

    public static Integer getMax(List<Integer> list)

    {

        return list.stream()                        // Stream<Integer>

                    .mapToInt(v -> v)               // IntStream

                    .max()                          // OptionalInt

                    .orElse(Integer.MIN_VALUE);     // Integer

    }

    Скачать  Выполнить код

    2. Использование Stream.max() метод

    Идея состоит в том, чтобы преобразовать список в Stream и позвони Stream#max() который принимает Comparator сравнивать элементы в потоке друг с другом, чтобы найти максимальный элемент, и возвращает Optional содержащий максимальный элемент в потоке в соответствии с предоставленным Comparator.

    // Метод поиска максимального элемента из списка целых чисел в Java 8 и выше

    public static Integer getMax(List<Integer> list)

    {

        return list.stream()                        // Stream<Integer>

                    .max(Comparator.naturalOrder()) // Optional<Integer>

                    .get();                         // Integer

    }

    Скачать  Выполнить код

     
    С Comparator функциональный интерфейс, Integer.compare() принимает два целых числа в качестве аргумента и возвращает целочисленное значение, подобное Comparator#compare(), он соответствует этому интерфейсу.

    // Метод поиска максимального элемента из списка целых чисел в Java 8 и выше

    public static Integer getMax(List<Integer> list)

    {

        return list.stream()                // Stream<Integer>

                    .max(Integer::compare)  // Optional<Integer>

                    .get();                 // Integer

    }

    Скачать  Выполнить код

    3. Операция редукции

    Мы также можем выполнить операцию сокращения над элементами потока, используя Integer#max() метод, который затем возвращает Optional описывающее уменьшенное значение, которое будет максимальным имеющимся значением.

    // Метод поиска максимального элемента из списка целых чисел в Java 8 и выше

    public static Integer getMax(List<Integer> list)

    {

        return list.stream()                // Stream<Integer>

                    .reduce(Integer::max)   // Optional<Integer>

                    .get();                 // Integer

    }

    Скачать  Выполнить код

    Мы также можем использовать перегруженную версию reduce() метод, который выполняет сокращение элементов потока, используя предоставленное значение идентификатора и ассоциативную функцию накопления, и возвращает уменьшенное значение.

    // Метод поиска максимального элемента из списка целых чисел в Java 8 и выше

    public static Integer getMax(List<Integer> list)

    {

        return list.stream()

                .reduce(Integer.MIN_VALUE, Integer::max);

    }

    Скачать  Выполнить код

    4. Использование коллекторов

    Мы также можем использовать Collectors чтобы найти максимальный элемент в списке.

    1. Collectors#maxBy() возвращает Collector который производит максимальный элемент в соответствии с заданным Comparator.

    // Метод поиска максимального элемента из списка целых чисел в Java 8 и выше

    public static Integer getMax(List<Integer> list)

    {

        return list.stream()

                .collect(Collectors.maxBy(Comparator.naturalOrder()))

                .get();

    }

    Скачать  Выполнить код

     
    2. Collectors#summarizingInt() возвращает Collector, который применяет int-производящий метод сопоставления к каждому входному элементу и возвращает сводную статистику для результирующих значений.

    Возвращенный IntSummaryStatistics Объект содержит статистику, такую как количество, минимум, максимум, сумма и среднее значение.

    // Метод поиска максимального элемента из списка целых чисел в Java 8 и выше

    public static Integer getMax(List<Integer> list)

    {

        return list.stream()

                    .collect(Collectors.summarizingInt(Integer::intValue))

                    .getMax();

    }

    Скачать  Выполнить код

     
    3. Collectors#reducing() возвращает Collector который выполняет сокращение своих входных элементов под заданным BinaryOperator и возвращает Optional.

    // Метод поиска максимального элемента из списка целых чисел в Java 8 и выше

    public static Integer getMax(List<Integer> list)

    {

        return list.stream()

                    .collect(Collectors.reducing(Integer::max))

                    .get();

    }

    Скачать  Выполнить код

    5. Использование сортировки

    Это самый простой, но самый неэффективный способ. Идея состоит в том, чтобы отсортировать поток в обратном порядке, тогда первый элемент потока будет максимальным элементом.

    // Метод поиска максимального элемента из списка целых чисел в Java 8 и выше

    public static Integer getMax(List<Integer> list)

    {

        return list.stream()

                    .sorted(Comparator.<Integer>reverseOrder())

                    .findFirst()

                    .get();

    }

    Скачать  Выполнить код

     
    Избегать NullPointerException если данный список нулевой и NoSuchElementException если данный список пуст, мы можем добавить следующий код ко всем вышеперечисленным методам в начале:

    if (list == null || list.size() == 0) {

        return Integer.MIN_VALUE;

    }

    Это все о поиске максимального элемента из списка целых чисел с использованием Stream в Java.

     
    Использованная литература:

    1. Поток Javadoc SE 8
    2. Коллекторы Javadoc SE 8

    Понравилась статья? Поделить с друзьями:
  • Как найти земли принадлежащие муниципалитету
  • Как исправить плохую покраску стены
  • Как найти мобильный телефон по спутнику бесплатно
  • Как составить формулы веществ с натрием
  • Как найти девушка узбеки