0 / 0 / 0
Регистрация: 27.12.2015
Сообщений: 16
1

Разработать рекурсивную функцию,возвращающую значение,для вычисления наибольшего значения в одномерном массиве

30.03.2016, 11:33. Показов 1077. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Разработать рекурсивную функцию,возвращающую значение,для вычисления наибольшего значения в одномерном массиве
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
30.03.2016, 11:33
Ответы с готовыми решениями:

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

Рекурсивная функция для вычисления наибольшего значения в одномерном массиве
для вычисления наибольшего значения в одномерном массиве

Разработать рекурсивную функцию, возвращающую значение:
для вычисления значения функции Аккермана для неотрицательных чисел n и m. Функция Аккермана...

Разработать рекурсивную функцию, возвращающую значение
Разработать рекурсивную функцию, возвращающую значение: для вычисления значения функции:

3
Объявлятель переменных
1219 / 406 / 319
Регистрация: 24.09.2011
Сообщений: 1,260
30.03.2016, 11:55 2
C++
1
2
3
4
int getMax (int *a, int n) {
    int m=n==1?a[0]:getMax(a,n-1);
    return a[n-1]>m?a[n-1]:m;
}
0
322 / 170 / 24
Регистрация: 25.03.2012
Сообщений: 712
30.03.2016, 15:20 3
Цитата Сообщение от vladosik337 Посмотреть сообщение
Разработать рекурсивную функцию,возвращающую значение,для вычисления наибольшего значения в одномерном массиве
Часто рекурсивные решения эффективны и имеют смысл, когда на шаге рекурсии удаётся разделить исходный набор данных (ваш массив) на 2 меньших примерно равного объёма (на этом сортировка Хоара или его же возведение в степень строятся).
В вашем случае (поиск максимума) это особого смысла не имеет, но может быть так:
C++
1
2
3
4
5
6
7
8
9
10
11
int get_max( int *arr, int size ) {
   if( 1 == size )
      return arr[ 0 ];
   if( 2 == size )
      return arr[ 0 ] > arr[ 1 ] ?
             arr[ 0 ] : arr[ 1 ];
   int m = size / 2,
       ml = get_max( arr, m ),
       mr = get_max( arr + m, size - m );
   return ml > mr ? ml : mr;
}
0
Объявлятель переменных
1219 / 406 / 319
Регистрация: 24.09.2011
Сообщений: 1,260
30.03.2016, 16:30 4
Прёт меня сегодня. Монстр с учётом замечания от Olej.
C++
1
2
3
4
5
// Очередное безобразие. a — массив, s — первый элемент массива, n — длина диапазона
int gM(int *a, int s, int n) {
    int m1,m2;
    return n==1?a[s]:n==2?a[s]>a[s+1]?a[s]:a[s+1]:(m1=gM(a,s,n/2))>(m2=gM(a,s+n/2,n-n/2))?m1:m2;
}
C++
1
2
3
4
5
// Или так
int gM(int *a, int n) {
    int m1, m2, nn;
    return n==1?a[0]:n==2?a[0]>a[1]?a[0]:a[1]:(m1=gM(a,(nn=n/2)))>(m2=gM(a+nn,n-nn))?m1:m2;
}
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
30.03.2016, 16:30
Помогаю со студенческими работами здесь

Разработать рекурсивную функцию, возвращающую значение:
Разработать рекурсивную функцию, возвращающую значение для вычисления наибольшего значения в...

Создание рекурсивной функции, возвращающей значение для вычисления наибольшего размера в одномерном массиве
сем доброго времени суток. Собственно сама задача: Разработать рекурсивную функцию возвращающую...

Разработать рекурсивную функцию для вычисления значения функции Аккермана для неотрицательных чисел n и m
Разработать рекурсивную функцию:для вычисления значения функции Аккермана для неотрицательных чисел...

Разработать подпрограмму-функцию для вычисления произведения двух самых больших чисел, размещенных одномерном массиве
Разработать подпрограмму-функцию для вычисления произведения двух самых больших чисел, размещенных...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru