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

Рекурсивное вычисление функции - C++

Восстановить пароль Регистрация
 
[CN]Defender
1 / 1 / 0
Регистрация: 25.09.2009
Сообщений: 56
30.01.2010, 22:19     Рекурсивное вычисление функции #1
Функция f(n) определяется рекурсивно: f(2*n)=f(n),f(2*n+1)=f(n)+f(n+1), f(0)=0,f(1)=1.написать программу вычисляющую функцию f(n)
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
30.01.2010, 22:19     Рекурсивное вычисление функции
Посмотрите здесь:

Рекурсивное вычисление C++
Рекурсивное вычисление НОК C++
C++ Рекурсивное вычисление суммы.
Рекурсивное вычисление корня k-й степени C++
Рекурсивное и нерекурсивное вычисление функции C++
C++ Рекурсивное вычисление значения функции
C++ Рекурсивное вычисление цепной дроби
Рекурсивное вычисление x!-sin(x) C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
logiC
16 / 16 / 2
Регистрация: 06.06.2009
Сообщений: 50
30.01.2010, 23:12     Рекурсивное вычисление функции #2
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Считаю, что задача имеет смысл только если n принадлежит множеству целых чисел.
Так что работаем только с int'ами:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
int f(int x)
{
      if(x == 0)
           return 0;
      if(x == 1)
            return 1;//условие выхода из рекурсии
      if(x%2 == 0) //проверяем на четность\нечетность
            //если четное число
            return f(x/2);
      else
      //число нечетное
      {
            int tmp = (x-1)/2;
            int ret = f(tmp)+f(tmp+1);
            return ret;
      } 
}
Yandex
Объявления
30.01.2010, 23:12     Рекурсивное вычисление функции
Ответ Создать тему
Опции темы

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