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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
diaryofsummer
1 / 1 / 0
Регистрация: 19.02.2012
Сообщений: 31
#1

рекурсия, итеративный метод - C++

07.04.2012, 22:30. Просмотров 467. Ответов 1
Метки нет (Все метки)

помогите пожалуйста написать программу для итеративного способа вычисления.
нужно вычислить элементы последовательности

a(n) = a(n div 2) + a(n div 3), n>1
a(0)=1

я написал программу для рекурсии, а как через цикл задать не могу сообразить...

C++
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
27
28
29
#include "stdafx.h"
#include <conio.h>
#include <iostream>
using namespace std;
 
int formula(int n)
{
    if (n<0)
    {
        cout<<"error";
        getch();
        exit(1);
    }
   
    if (n==0) return 1;
    return formula(n/2)+formula(n/3);
}
 
int _tmain(int argc, _TCHAR* argv[])
{
    int n;
    int i;
    cout<<"n = ";
    cin>>n;
    cout<<" = "<<formula(n);
     
    getch();
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.04.2012, 22:30     рекурсия, итеративный метод
Посмотрите здесь:

C++ Метод итераций и метод Зейделя
рекурсия C++
C++ Итеративный поиск в глубину
Рекурсивный и итеративный метод C++
Есть метод класса внутри , есть проверка. Если условие сходится то метод должен выдать указатель, иначе булевую переменную C++
Метод простой итерации с заданной точностью (рекурсия) C++
C++ Метод оптимизации. Метод Фибоначчи
Итеративный и рекурсивный методом вычисления ln 1 + x, через разложение в ряд C++
C++ Метод парных перестановок и метод подсчета
C++ Рекурсивный и итеративный методы разворачивания числа
Метод пузырька и метод слияния C++
C++ Вызвать метод через указатель на метод

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
alex_x_x
бжни
 Аватар для alex_x_x
2441 / 1646 / 84
Регистрация: 14.05.2009
Сообщений: 7,163
07.04.2012, 22:35     рекурсия, итеративный метод #2
C++
1
2
3
4
5
6
7
8
9
10
// a(n) = a(n div 2) + a(n div 3), n>1
// a(0)=1
 
const size_t n = 8;
size_t i;
int an[n] = { 0 };
for (i = 1 ; i <= n ; ++i)
{
  an[i] = an[i / 2] + an[i / 3]; 
}
Yandex
Объявления
07.04.2012, 22:35     рекурсия, итеративный метод
Ответ Создать тему
Опции темы

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