Как в массиве найти минимум функции

В этом посте мы обсудим, как найти минимальный и максимальный элемент массива в C++.

1. Наивное решение

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

#include <iostream>

#include <climits>

#include <algorithm>

using namespace std;

int main()

{

    int arr[] = { 4, 2, 1, 6, 8, 5 };

    int min = INT_MAX, max = INT_MIN;

    for (int i: arr)

    {

        if (i < min) {

            min = i;

        }

        if (i > max) {

            max = i;

        }

    }

    std::cout << «The min element is « << min << std::endl;

    std::cout << «The max element is « << max << std::endl;

    return 0;

}

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

результат:

The min element is -8
The max element is 6

2. Использование minmax_element() функция

Рекомендуемое решение — использовать std::minmax_element найти наименьший и наибольший элементы массива. Он возвращает пару итераторов, первое значение которых указывает на минимальный элемент, а второе значение указывает на максимальный элемент. Он определен в <algorithm> заголовок.

#include <iostream>

#include <algorithm>

using namespace std;

int main()

{

    int arr[] = { 4, 2, 1, 6, 8, 5 };

    std::pair<int*, int*> minmax = std::minmax_element(std::begin(arr), std::end(arr));

    std::cout << «The min element is « << *(minmax.first) << std::endl;

    std::cout << «The max element is « << *(minmax.second) << std::endl;

    return 0;

}

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

результат:

The min element is -8
The max element is 6

3. Использование min_element() с max_element() функция

Стандартная библиотека C++ также предоставляет отдельные функции. min_element() а также max_element() чтобы найти наименьший и наибольший элементы в массиве соответственно.

#include <iostream>

#include <algorithm>

using namespace std;

int main()

{

    int arr[] = { 4, 2, 1, 6, 8, 5 };

    int *min = std::min_element(std::begin(arr), std::end(arr));

    int *max = std::max_element(std::begin(arr), std::end(arr));

    std::cout << «The min element is « << *min << std::endl;

    std::cout << «The max element is « << *max << std::endl;

    return 0;

}

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

результат:

The min element is -8
The max element is 6

Вот и все, что касается нахождения минимального и максимального значений в массиве в C++.

0 / 0 / 0

Регистрация: 05.01.2022

Сообщений: 26

1

Найти минимум и максимум функции по одномерному массиву

25.01.2022, 18:15. Показов 975. Ответов 4


Студворк — интернет-сервис помощи студентам

Составить программу, предусматривающую обработку значений одномерного массива. Ввод/вывод осуществлять с использованием компонентов классов TextBox.
Даны вещественный массив A размером n и вещественный массив X размером m. Найти минимум и максимум функции Y=[I]aᵢ x

Добавлено через 58 минут
Найти минимум и максимум функции Y=aᵢ x



0



297 / 130 / 74

Регистрация: 23.08.2015

Сообщений: 422

26.01.2022, 08:22

2

Я правильно понимаю — нужно найти минимальное и максимальное произведение одного элемента одного массива и одного элемента другого массива (из всех возможных)?
Могут задаваться отрицательные числа?

Нужен классический алгоритм или можно через Linq?

Добавлено через 30 минут
Каким образом вводятся значения массива в TextBox, как разделяются?



0



0 / 0 / 0

Регистрация: 05.01.2022

Сообщений: 26

26.01.2022, 11:13

 [ТС]

3

Найти минимум и максимум функции Y=ai xj для различных пар элементов массивов (i=1..n; j=1..m).
Через Linq
Значения полученного будут отображаться в одном TextBox



0



0 / 0 / 0

Регистрация: 05.01.2022

Сообщений: 26

26.01.2022, 12:08

 [ТС]

4

Найти минимум и максимум функции по одномерному массиву



0



297 / 130 / 74

Регистрация: 23.08.2015

Сообщений: 422

27.01.2022, 08:55

5

Лучший ответ Сообщение было отмечено Jiferkil как решение

Решение

Данные вводятся в TextBox`ы по одному значению сверху вниз.



1



Another approach (more words, less code) that may help:

The locations of local maxima and minima are also the locations of the zero crossings of the first derivative. It is generally much easier to find zero crossings than it is to directly find local maxima and minima.

Unfortunately, the first derivative tends to «amplify» noise, so when significant noise is present in the original data, the first derivative is best used only after the original data has had some degree of smoothing applied.

Since smoothing is, in the simplest sense, a low pass filter, the smoothing is often best (well, most easily) done by using a convolution kernel, and «shaping» that kernel can provide a surprising amount of feature-preserving/enhancing capability. The process of finding an optimal kernel can be automated using a variety of means, but the best may be simple brute force (plenty fast for finding small kernels). A good kernel will (as intended) massively distort the original data, but it will NOT affect the location of the peaks/valleys of interest.

Fortunately, quite often a suitable kernel can be created via a simple SWAG («educated guess»). The width of the smoothing kernel should be a little wider than the widest expected «interesting» peak in the original data, and its shape will resemble that peak (a single-scaled wavelet). For mean-preserving kernels (what any good smoothing filter should be) the sum of the kernel elements should be precisely equal to 1.00, and the kernel should be symmetric about its center (meaning it will have an odd number of elements.

Given an optimal smoothing kernel (or a small number of kernels optimized for different data content), the degree of smoothing becomes a scaling factor for (the «gain» of) the convolution kernel.

Determining the «correct» (optimal) degree of smoothing (convolution kernel gain) can even be automated: Compare the standard deviation of the first derivative data with the standard deviation of the smoothed data. How the ratio of the two standard deviations changes with changes in the degree of smoothing cam be used to predict effective smoothing values. A few manual data runs (that are truly representative) should be all that’s needed.

All the prior solutions posted above compute the first derivative, but they don’t treat it as a statistical measure, nor do the above solutions attempt to performing feature preserving/enhancing smoothing (to help subtle peaks «leap above» the noise).

Finally, the bad news: Finding «real» peaks becomes a royal pain when the noise also has features that look like real peaks (overlapping bandwidth). The next more-complex solution is generally to use a longer convolution kernel (a «wider kernel aperture») that takes into account the relationship between adjacent «real» peaks (such as minimum or maximum rates for peak occurrence), or to use multiple convolution passes using kernels having different widths (but only if it is faster: it is a fundamental mathematical truth that linear convolutions performed in sequence can always be convolved together into a single convolution). But it is often far easier to first find a sequence of useful kernels (of varying widths) and convolve them together than it is to directly find the final kernel in a single step.

Hopefully this provides enough info to let Google (and perhaps a good stats text) fill in the gaps. I really wish I had the time to provide a worked example, or a link to one. If anyone comes across one online, please post it here!

Прошу пояснить что делает функция minimal(построчно) и для чего мы выполняем то или иное действие в функции minimal. В частности, я не понимаю что делает k=size>>1, array+k и size-k.

#include <stdio.h>
#include <conio.h>
     
int minimal (int *array, int size)
{
    int l, r, k;
     
    if (size==1) 
        return *array;
     
    l = minimal(array, k=size>>1);
    r = minimal(array+k, size-k);
     
    return l < r ? l : r; 
}
     
void main(void) 
{
    int i;
    int a[10];
     
    for(i=0; i<10; i++)
    {
        printf("Vvedite znachenie elemnte %d massiva a: ", i);
        scanf("%d", &a[i]);
    }
    printf ("Minimalnoe znachenie massiva = %d", minimal(a,10));
    getch();
}

V-Mor's user avatar

V-Mor

5,1171 золотой знак13 серебряных знаков31 бронзовый знак

задан 18 ноя 2020 в 20:45

Vladislav's user avatar

1

Опираясь на комментарий @avp, распишу немного подробнее.

Во-первых, соглашусь с комментатором, что это то ещё извращение.

Во-вторых, по непонятному:

  1. k=size>>1: здесь используется оператор побитового сдвига >>. Он сдвигает двоичное представление числа вправо на столько бит, сколько стоит после >>. В данном случае на 1. То есть, если, например, size в двоичном виде был 1000100110001011, то станет 0100010011000101 (сдвинулось вправо на 1, самый правый элемент пропал, слева добавился 0). В данном случае это сделано для простого деления на 2 с округлением в меньшую сторону. То есть, эквивалентной записью было бы k = floor(size / 2). Но сдвигом это работает быстрее (процессору так проще).
  2. array+k наращивает указатель на массив на k. Теперь, при рекурсивном вызове функции, array будет начинаться не с нулевого элемента, а с k-ого. Это аналогично передаче указателя на k-ый элемент массива вот так: &array[k].
  3. size - k – здесь всё просто. На предыдущей строке k присваивается половина размера массива с округлением в меньшую сторону, а значит оставшаяся часть массива, те самые size - k элементов идут в следующий рекурсивный вызов.
  4. Назначение функции – найти наименьший элемент массива с помощью дробления его на половинки, тех половинок на ещё половинки и так далее, пока половинки не станут размером в 1 элемент. Потом выбирается, какая из половинок больше, и возвращается в результат.
  5. Бонусом расскажу, что значит запись l < r ? l : r. Вдруг это тоже не понятно. Это аналогично простому условию if. Всё, что до знака ? – условие. Между вопросом и : – действие, если условие выполнено. Всё, что после : – если не выполнено. То есть в данном случае это можно переписать как:
if (l < r)
    return l;
else
    return r;

P.S. Я пояснил только непонятные моменты. Если Вам непонятно абсолютно всё, Вам не сюда, а в учебники по C.

ответ дан 19 ноя 2020 в 1:59

V-Mor's user avatar

V-MorV-Mor

5,1171 золотой знак13 серебряных знаков31 бронзовый знак

Самый простой способ

Разумеется, проще всего получить минимальный и максимальный элементы массива с помощью функций min() и max():

$arr = [8, 4, 12, 9];
$max = max($arr); // 12
$min = min($arr); // 4

Однако на форумах часто просят написать скрипт, не использующий эти функции. Чаще всего этого требуют преподаватели учебных учреждений.

Условия задачи

1. Найти наибольший наименьший элементы в одномерном числовом массиве.
2. Определить номер минимального и максимального элементов заданного одномерного массива.
3. Найти минимальное и максимальное значение в ассоциативном массиве.

Общий принцип поиска элементов

Во всех решениях мы будем использовать одну и ту же логику.

Согласно условию, нам необходимо объявить числовой массив произвольной длины. Также объявим 4 переменные, в которые будем помещать найденные значения и их ключи:

<?php
$arr = [12, 4, 182, 1, 2.587];
$min = null;
$min_key = null;
$max = null;
$max_key = null;

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

И если больше — будем записывать в $max новое максимальное значение, а в $max_key его ключ. Абсолютно также поступим и с минимальными ключом и значением.

Пример с циклом foreach:

foreach($arr as $k => $v)
{
	if($v > $max)
	{
		$max = $v;
		$max_key = $k;
	}

	if($v < $min)
	{
		$min = $v;
		$min_key = $k;
	}
}

На данном этапе наш код уже будет работать, но это ещё не всё. Попробуем изменить исходный массив и посмотрим на результат:

<?php
$arr = [0, -12];
$max = null;

foreach($arr as $v)
{
	if($v > $max)
		$max = $v;
}

var_dump($max); // -12

Максимальным должно быть число 0, но скрипт вывел -12. Дело в том, что PHP не считает истинным выражение 0 > null, поэтому ноль на первой итерации цикла не записался в переменную $max.

Для решения этой проблемы просто добавим условие, что если $max === null, т.е. если это первая итерация, то в любом случае записываем текущее значение в $min и $max:

<?php
$arr = [0, -12];
$max = null;

foreach($arr as $v)
{
    if($v > $max or $max === null)
        $max = $v;
}

var_dump($max); // -12

Минимальный и максимальный элементы с циклом FOREACH

Решение:

<?php
$arr = [12, 4, 182, 1, 2.587];
$min = null;
$min_key = null;
$max = null;
$max_key = null;

foreach($arr as $k => $v)
{
	if($v > $max or $max === null)
	{
		$max = $v;
		$max_key = $k;
	}

	if($v < $min or $min === null)
	{
		$min = $v;
		$min_key = $k;
	}
}

echo "Min value: $min <br> Min key: $min_key <br>";
echo "Max value: $max <br> Max key: $max_key";

Минимальный и максимальный элементы с циклом WHILE

Решение 1: счётчик + count()

Цикл будет выполняться до тех пор, пока значение счётчика $i не превысит количество элементов массива.

<?php
$arr = [12, 4, 182, 1, 2.587];
$min = null;
$min_key = null;
$max = null;
$max_key = null;
$i = 0;

while($i < count($arr))
{
    if($arr[$i] > $max or $max === null)
    {
        $max = $arr[$i];
        $max_key = $i;
    }

    if($arr[$i] < $min or $min === null)
    {
        $min = $arr[$i];
        $min_key = $i;
    }

	$i++;
}

echo "Min value: $min <br> Min key: $min_key <br>";
echo "Max value: $max <br> Max key: $max_key";

Решение 2: счётчик + isset()

Запускаем вечный цикл while и в каждой итерации цикла проверяем существование следующего элемента с помощью isset(). Если его нет — выходим из цикла оператором break:

<?php
$arr = [12, 4, 182, 1, 2.587];
$min = null;
$min_key = null;
$max = null;
$max_key = null;
$i = 0;

while(true)
{
	if(isset($arr[$i]))
	{
		if($arr[$i] > $max or $max === null)
		{
			$max = $arr[$i];
			$max_key = $i;
		}

		if($arr[$i] < $min or $min === null)
		{
			$min = $arr[$i];
			$min_key = $i;
		}
	}
	else
		break;

	$i++;
}

echo "Min value: $min <br> Min key: $min_key <br>";
echo "Max value: $max <br> Max key: $max_key";

Решение 3: list() + each()

Функция each() возвращает ключ и значение текущего элемента массива и смещает его внутренний указатель на единицу. Функция list() используется просто для удобства — с её помощью мы превращаем массив, который возвращает функция each, в две разные переменные:

<?php
$arr = [12, 4, 182, 1, 2.587];
$min = null;
$min_key = null;
$max = null;
$max_key = null;
$i = 0;

while(list($k, $v) = each($arr))
{
	if($v > $max or $max === null)
	{
		$max = $v;
		$max_key = $k;
	}

	if($v < $min or $min === null)
	{
		$min = $v;
		$min_key = $k;
	}
}

echo "Min value: $min <br> Min key: $min_key <br>";
echo "Max value: $max <br> Max key: $max_key";

Получился практически аналог foreach. Единственный минус в том, что начиная с PHP 7.2 функция each() объявлена устаревшей.

Решение 4: current() + next()

Это решение похоже на предыдущее с each(). Получаем текущий элемента массива функцией current() и смещаем внутренний указатель массива функцией next(). Получить текущий ключ массива можно с помощью функции key().

<?php
$arr = [12, 4, 182, 1, 2.587];
$min = null;
$min_key = null;
$max = null;
$max_key = null;
$i = 0;

while($v = current($arr))
{
	if($v > $max or $max === null)
	{
		$max = $v;
		$max_key = key($arr);
	}

	if($v < $min or $min === null)
	{
		$min = $v;
		$min_key = key($arr);
	}

	next($arr);
}

echo "Min value: $min <br> Min key: $min_key <br>";
echo "Max value: $max <br> Max key: $max_key";

Наибольший и наименьший элементы с циклом FOR

Решение 1: счётчик + count()

Вводим счётчик $i и увеличиваем его после каждой итерации. Цикл прекратится как только значение счётчика превысит количество элементов массива.

<?php
$arr = [12, 4, 182, 1, 2.587];
$min = null;
$min_key = null;
$max = null;
$max_key = null;

for($i = 0; $i < count($arr); $i++)
{
    if($arr[$i] > $max or $max === null)
    {
        $max = $arr[$i];
        $max_key = $i;
    }

    if($arr[$i] < $min or $min === null)
    {
        $min = $arr[$i];
        $min_key = $i;
    }
}

echo "Min value: $min <br> Min key: $min_key <br>";
echo "Max value: $max <br> Max key: $max_key";

Решение 2: счётчик + isset()

В отличие от предыдущего варианта, мы не смотрим на количество элементов массива, а запускаем вечный цикл и в каждой итерации проверяем существование следующего элемента, и если его нет — прерываем цикл командой break:

<?php
$arr = [12, 4, 182, 1, 2.587];
$min = null;
$min_key = null;
$max = null;
$max_key = null;

for($i = 0; true; $i++)
{
	if(!isset($arr[$i]))
		break;

    if($arr[$i] > $max or $max === null)
    {
        $max = $arr[$i];
        $max_key = $i;
    }

    if($arr[$i] < $min or $min === null)
    {
        $min = $arr[$i];
        $min_key = $i;
    }
}

echo "Min value: $min <br> Min key: $min_key <br>";
echo "Max value: $max <br> Max key: $max_key";

Решение 3: each() + list()

Функция each() возвращает массив с ключом и значением текущего элемента массива, а list() превращает этот массив в 2 разные переменные. После последнего элемента функция each() вернёт false и цикл прекратит работу.

<?php
$arr = [12, 4, 182, 1, 2.587];
$min = null;
$min_key = null;
$max = null;
$max_key = null;
$i = 0;

for(; list($k, $v) = each($arr);)
{
    if($v > $max or $max === null)
    {
        $max = $v;
        $max_key = $k;
    }

    if($v < $min or $min === null)
    {
        $min = $v;
        $min_key = $k;
    }
}

echo "Min value: $min <br> Min key: $min_key <br>";
echo "Max value: $max <br> Max key: $max_key";

Решение 4: current() + next()

С помощью функции next() смещаем внутренний указатель массива, а функции current() и key() возвращают текущие ключ и значение. Первое и последнее выражение цикла оставляем пустыми.

<?php
$arr = [12, 4, 182, 1, 2.587];
$min = null;
$min_key = null;
$max = null;
$max_key = null;
$i = 0;

for(; $v = current($arr);)
{
	if($v > $max or $max === null)
	{
		$max = $v;
		$max_key = key($arr);
	}

	if($v < $min or $min === null)
	{
		$min = $v;
		$min_key = key($arr);
	}

	next($arr);
}

echo "Min value: $min <br> Min key: $min_key <br>";
echo "Max value: $max <br> Max key: $max_key";

Максимальное значение в ассоциативном массиве

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

Но мы всё ещё можем использовать цикл foreach и те решения для while и for, где используются функции each() и next(), поскольку они используют не ключи, а внутренний указатель массива.

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