Форум программистов, компьютерный форум CyberForum.ru

Рекурсивная функция С++ - C++

Восстановить пароль Регистрация
 
ZooMiGs
Сообщений: n/a
18.09.2012, 19:30     Рекурсивная функция С++ #1
Написать рекурсивную функцию (+ саму программу), которая подсчитывает сумму элементов одномерного массива.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.09.2012, 19:30     Рекурсивная функция С++
Посмотрите здесь:

рекурсивная функция C++
C++ Рекурсивная функция!
C++ рекурсивная функция
C++ Рекурсивная функция
C++ Рекурсивная функция
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
bgm313
12 / 12 / 2
Регистрация: 27.07.2012
Сообщений: 208
18.09.2012, 20:53     Рекурсивная функция С++ #2
Вот тебе функция. С остальным справишься сам)

C++
1
2
3
4
5
6
7
8
int sumArray(int nums[], int sizeArray){
    int result = 0;
    
    if(!sizeArray) return result;
    
    result = nums[sizeArray - 1] + sumArray(nums, sizeArray - 1);
    return result;
}
Thinker
Эксперт C++
 Аватар для Thinker
4215 / 2189 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
18.09.2012, 21:07     Рекурсивная функция С++ #3
Почему бы не в одну строчку
C++
1
2
3
4
5
6
7
int Sum(int *a, int *end)
{
   return a < end ? *a + Sum (a + 1, end) : 0;
}
 
...
Sum(a, a + n)
serejkus
46 / 44 / 4
Регистрация: 31.10.2011
Сообщений: 98
19.09.2012, 00:31     Рекурсивная функция С++ #4
Зато версия bgm313 с большей вероятностью будет подвергнута tail-recursion оптимизации (особенно, если не создавать result).
OhMyGodSoLong
~ Эврика! ~
 Аватар для OhMyGodSoLong
1234 / 983 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
19.09.2012, 02:13     Рекурсивная функция С++ #5
Цитата Сообщение от serejkus Посмотреть сообщение
Зато версия bgm313 с большей вероятностью будет подвергнута tail-recursion оптимизации (особенно, если не создавать result).
У этой версии вероятность не хуже:
C++
1
2
3
4
5
6
7
8
9
int Sum(int *a, int *end, int result = 0)
{
  if (a >= end) {
    return result;
  }
  else {
    return Sum(a + 1, end, result + *a);
  }
}
Кликните здесь для просмотра всего текста
А вариант
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
int Sum(int *a, int *end)
{
  int result = 0;
past:
  if (a >= end) {
    return result;
  }
  else {
    result += *a;
    a += 1;
    goto past;
  }
}
гарантированно заоптимизирован ^^
Yandex
Объявления
19.09.2012, 02:13     Рекурсивная функция С++
Ответ Создать тему
Опции темы

Текущее время: 17:34. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru