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

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

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 16, средняя оценка - 4.75
Steam.dll
 Аватар для Steam.dll
3 / 3 / 0
Регистрация: 05.11.2010
Сообщений: 131
19.03.2011, 12:59     Рекурсивные функции #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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <string.h>
#include <math.h>
#include <time.h>
#include <iostream>
using namespace std;
int factorial(int n);
int main(void)
{
    const int m=8;
    int x=1,i;
    unsigned int *MAS;
    MAS=new unsigned int [m];
    
    for(i=0;i<8;i++)
    {
        MAS[i]=(x++)*2;
        printf(" %d",MAS[i]);
    }
    return 0;
}
int factorial(int n)
{  
    unsigned int *MAS;
    n=16;
    const int m=8;
    unsigned int *MAS2;
    MAS2=new unsigned int [m];
    
    for(int i=0;i<8;i++)
    {
     if(MAS[i]>1)
     {
         MAS2[i]=(MAS[i])*(factorial(n-1));
         printf(" %d",MAS2[i]);
         
     }
     else
     {
         MAS2[i]=1;
     }
    }
    
    return 0;
}
как работают рекурсивные функции ?
Миниатюры
Рекурсивные функции  
Лучшие ответы (1)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9371 / 5421 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
19.03.2011, 13:19     Рекурсивные функции #2
Это же классика жанра!
C
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <stdio.h>
#include <stdint.h> // ANSI C 99. Как в мелкомягких компиляторах длинные числа пишутся - см. MSDN
 
uint64_t fact(uint64_t num) { return num < 2 ? 1 : num * fact(num - 1); }
 
int main(void){
    uint64_t num;
    
    while ( printf("Number: ") && scanf("%llu", &num) == 1 )
        printf("Factorial: %llu\n", fact(num));
    
    return 0;
}
Steam.dll
 Аватар для Steam.dll
3 / 3 / 0
Регистрация: 05.11.2010
Сообщений: 131
19.03.2011, 13:49  [ТС]     Рекурсивные функции #3
Спасибо но мне не понятно это я на 1 курсе еще.
Вот в моей програме что то неправильно и я хочу понять .
Kastaneda
Модератор
Эксперт С++
 Аватар для Kastaneda
4236 / 2769 / 218
Регистрация: 12.12.2009
Сообщений: 7,104
Записей в блоге: 1
Завершенные тесты: 1
19.03.2011, 13:51     Рекурсивные функции #4
Цитата Сообщение от Steam.dll Посмотреть сообщение
как работают рекурсивные функции ?
должно помочь
Steam.dll
 Аватар для Steam.dll
3 / 3 / 0
Регистрация: 05.11.2010
Сообщений: 131
19.03.2011, 15:12  [ТС]     Рекурсивные функции #5
Вроде понял а с заданием справится не могу. Помогите.
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
19.03.2011, 15:25     Рекурсивные функции #6
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Не совсем рекурсия но все же)

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream>
 
template<int N>
struct fac
{
    static const int fact=N*fac<N-1>::fact;
};
 
template<>
struct fac<0>
{
    static const int fact=1;
};
 
int main()
{
    std::cout<<fac<5>::fact<<'\n';
}
Steam.dll
 Аватар для Steam.dll
3 / 3 / 0
Регистрация: 05.11.2010
Сообщений: 131
19.03.2011, 15:30  [ТС]     Рекурсивные функции #7
У меня почему то компелятор ошибок много выдаёт
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
19.03.2011, 15:36     Рекурсивные функции #8
Steam.dll, Что за компилятор? Пример ошибки в студию.

Добавлено через 4 минуты
Решение на Си.

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <stdio.h>
 
typedef unsigned long int value_type;
 
value_type factorial(int n)
{
    return n < 0 ? 0 : n < 2 ? 1 : n*factorial(n-1);
}
 
int main()
{
    int n=0;
    printf("Enter n: ");
    scanf("%lu", &n);
    value_type fact=0;
    int i=2;
    for(i; i<=n; i+=2)
        fact+=factorial(i);
    printf("%lu\n", fact);
    return 0; 
}
Steam.dll
 Аватар для Steam.dll
3 / 3 / 0
Регистрация: 05.11.2010
Сообщений: 131
19.03.2011, 16:47  [ТС]     Рекурсивные функции #9
Спасибо большое.

Добавлено через 23 минуты
А вот еще вопрос а тип данных "%lu" это long int ?
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
19.03.2011, 16:50     Рекурсивные функции #10
Steam.dll, unsigned long по умолчанию является unsigned long int.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
19.03.2011, 23:01     Рекурсивные функции
Еще ссылки по теме:

C++ Рекурсивные функции
Рекурсивные функции C++
Рекурсивные функции C++

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

Или воспользуйтесь поиском по форуму:
Steam.dll
 Аватар для Steam.dll
3 / 3 / 0
Регистрация: 05.11.2010
Сообщений: 131
19.03.2011, 23:01  [ТС]     Рекурсивные функции #11
спасибо
Yandex
Объявления
19.03.2011, 23:01     Рекурсивные функции
Ответ Создать тему
Опции темы

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