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

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

Восстановить пароль Регистрация
 
diaryofsummer
1 / 1 / 0
Регистрация: 19.02.2012
Сообщений: 31
07.04.2012, 22:30     рекурсия, итеративный метод #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++ Производный класс: метод возведения в произвольную степень, и метод для вычисления логарифма числа
Класс vector (поля: координаты, 2 конструктора, метод нахождения длины вектора и метод вывода координат на экран) C++
Метод простой итерации с заданной точностью (рекурсия) C++
Нахождения корней уравнения: метод половинного деления (бисекции) или метод хорд C++
Итеративный и рекурсивный методом вычисления ln 1 + x, через разложение в ряд 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     рекурсия, итеративный метод
Ответ Создать тему
Опции темы

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