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

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

Войти
Регистрация
Восстановить пароль
 
undertacker
9 / 9 / 0
Регистрация: 28.04.2013
Сообщений: 55
#1

рекурсия - C++

28.04.2013, 16:31. Просмотров 347. Ответов 3
Метки нет (Все метки)

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
#include <iostream>
#include <windows.h>
using namespace std;
 
void someFunction ( int [], int, int );
 
int main ()
{
 
 const int arraySize = 10;
 int a[arraySize] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
 cout << "The values in the array are:" << endl;
 someFunction( a, 0, arraySize );
 cout << endl;
 
 system ("Pause void");
 return 0;
     
}
 
void someFunction ( int b[], int current, int size )
{
        if ( current < size )
        {  
        someFunction ( b, current + 1, size ); // не пойму как работает 
        cout << b[ current ] << " " << endl;
        } 
}
Вообщем вопрос таков:
1 как работает эта рекурсия
2 причем тут current + 1
3 почему выводится массив в обратном порядке, если с начало b [ current ] = b[ 1 ] = 2
заранее спасибо)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.04.2013, 16:31     рекурсия
Посмотрите здесь:

Рекурсия - C++
Есть такой код. В нем рисуется что то вроде линейки. Данный код предназначен для иллюстрации работы рекурсии. Может мне кто нибудь...

Рекурсия - C++
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; const int n=4; void swap(int &amp;x,int &amp;x1); void pt(int* a1,int n1,int z); int main() ...

C++ Рекурсия - C++
Через рекурсию) Если можно, то исправьте код) http://www.cyberforum.ru/attachment.php?attachmentid=672269&amp;stc=1&amp;d=1459599977 ...

Рекурсия - C++
Разработать рекурсивную функцию не возврашающую значений: Дано натуральное четное число n. Разработать функцию для вывода на экран...

Рекурсия - C++
Как переделать программу в рекурсию? char S='S', T='T', M={NULL}; int ST=5,i=0,j=0; int TS; void Per() { M=S; ...

РЕкурсия - C++
Мне нужно 5 задач по рекурсии с решениями,)))есмли не сложно-помогите, может ссылочку куда или что-нибудь)))заранее благодарен

Рекурсия - C++
Не понимаю каков будет порядок действий в функции допустим когда(level =2). По тому как я понял работает рекурсия, когда начнется алгоритм...

Рекурсия - C++
Сегодня баловался с рекурсией. получилось типа цикла, только из функции #include &lt;iostream&gt; using namespace std; unsigned...

Рекурсия - C++
Задан массив целых чисел: а0, а1 ..., аn-1. Известно, что один из элементов массива принимает нулевое значение. Найти номер данного...

Рекурсия - C++
В общем нужно вывести биноминальные коэффициенты последовательности.... т.е есть последовательность - скажем вектор 12345 n = size =...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
yoghurt92
374 / 345 / 22
Регистрация: 17.05.2012
Сообщений: 1,049
28.04.2013, 17:05     рекурсия #2
undertacker, если хотите вот более понятный пример

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
#include <iostream>
#include <windows.h>
using namespace std;
 
void someFunction ( int [], int, int );
 
int main ()
{
 
 const int arraySize = 10;
 int a[arraySize] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
 cout << "The values in the array are:" << endl;
 someFunction( a, arraySize - 1, arraySize );
 cout << endl;
 
 system ("Pause void");
 return 0;
     
}
 
void someFunction ( int b[], int current, int size )
{
        if ( current >= 0 )
        {  
            cout << b[ current ] << " " << endl;
            someFunction ( b, current - 1, size ); 
        } 
}
а вообще current - 1 нужен для перехода к следующему элементу и естественное чтобы знать до каких пор выполнять рекурсию Но в первом случае мы сначала идем до конца массива а потом уже выводим значения, вот и получается что выводим с конца)
OhMyGodSoLong
~ Эврика! ~
1243 / 992 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
28.04.2013, 17:07     рекурсия #3
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
someFunction(a, 0, arraySize);
 
/* b => a, current => 0, size => arraySize */
if (current < size)
{  
    someFunction (b, current + 1, size);
    cout << b[current] << " " << endl;
}
 
if (0 < arraySize)
{  
    someFunction (a, 0 + 1, arraySize);
    cout << a[0] << " " << endl;
}
 
if (0 < arraySize)
{  
    /* b => a, current => 0 + 1 = 1, size => arraySize*/
    if (current < size)
    {
        someFunction(b, current + 1, size);
        cout << b[current] << " " << endl;
    }
    cout << a[0] << " " << endl;
}
 
if (0 < arraySize)
{  
    if (1 < arraySize)
    {
        someFunction(a, 1 + 1, arraySize);
        cout << a[1] << " " << endl;
    }
    cout << a[0] << " " << endl;
}
 
// ...
 
if (0 < arraySize)
{  
    if (1 < arraySize)
    {
        if (2 < arraySize)
        {
            if (3 < arraySize)
            {
                if (4 < arraySize)
                {
                    if (5 < arraySize)
                    {
                        if (6 < arraySize)
                        {
                            if (7 < arraySize)
                            {
                                if (8 < arraySize)
                                {
                                    if (9 < arraySize)
                                    {
                                        if (10 < arraySize)
                                        {
                                            someFunction(a, 10 + 1, arraySize);
                                            cout << a[10] << " " << endl;
                                        }
                                        cout << a[9] << " " << endl;
                                    }
                                    cout << a[8] << " " << endl;
                                }
                                cout << a[7] << " " << endl;
                            }
                            cout << a[6] << " " << endl;
                        }
                        cout << a[5] << " " << endl;
                    }
                    cout << a[4] << " " << endl;
                }
                cout << a[3] << " " << endl;
            }
            cout << a[2] << " " << endl;
        }
        cout << a[1] << " " << endl;
    }
    cout << a[0] << " " << endl;
}
Вот именно поэтому стоит читать SICP.
undertacker
9 / 9 / 0
Регистрация: 28.04.2013
Сообщений: 55
28.04.2013, 18:59  [ТС]     рекурсия #4
yoghurt92, Во! Спасибо большое, теперь понял
Yandex
Объявления
28.04.2013, 18:59     рекурсия
Ответ Создать тему
Опции темы

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