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

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

Войти
Регистрация
Восстановить пароль
 
Виkтория
 Аватар для Виkтория
1 / 1 / 0
Регистрация: 04.06.2013
Сообщений: 63
#1

как сделать через рекурсивную функцию ? - C++

11.06.2013, 20:04. Просмотров 246. Ответов 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
#include <iostream>
using std::cout;
using std::endl;
using std::cin;
const int n=100;
int main()
{
    int i=0,arr[n];
    setlocale (LC_ALL,"rus");
    cout << "Введите последовательность чисел:";
    do
    {
        cin>>arr[i++];
 
    }while(arr[i-1]!=0);
    int size=i;
    cout<<"В обратном порядке:";
    for (int i=size-1;i>=0;i-- )
    {
        cout << arr[i] << " ";
    };
    system ("pause>>void");
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.06.2013, 20:04     как сделать через рекурсивную функцию ?
Посмотрите здесь:

C++ Разработат рекурсивную функцию
C++ Написать рекурсивную функцию
дана программа на рекурсивную функцию надо разработать как рисунке C++
как сделать через функцию пользователя и чтобы размер мог вводить пользователь ? C++
Нахождение основных значений оформить через функцию RESHENIE(), ввод данных и вывод на печать через функцию MAIN() C++
Описать рекурсивную функцию C++
Задача на рекурсивную функцию C++
Изменение массива через рекурсивную функцию C++
C++ Использовать рекурсивную функцию
Попытка сделать поиск max и min значений массива через функцию C++
C++ Вывод на экран каждого второго элемента массива через рекурсивную функцию
C++ Редактировать рекурсивную функцию

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Croessmah
Модератор
Эксперт CЭксперт С++
 Аватар для Croessmah
12514 / 7076 / 794
Регистрация: 27.09.2012
Сообщений: 17,477
Записей в блоге: 2
Завершенные тесты: 1
11.06.2013, 20:10     как сделать через рекурсивную функцию ? #2
как вариант:
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
#include <iostream>
using std::cout;
using std::endl;
using std::cin;
const int n=100;
 
 
void foo(int * arr,int size){
    if(size>0){
        std::cout<<arr[--size]<<std::endl;
        foo(arr,size);
    }
}
 
int main()
{
    int i=0,arr[n];
    setlocale (LC_ALL,"rus");
    cout << "Введите последовательность чисел:";
    do
    {
        cin>>arr[i++];
 
    }while(arr[i-1]!=0);
    int size=i;
    cout<<"В обратном порядке: \n";
    foo(arr,size);
    system ("pause>>void");
    return 0;
}
Виkтория
 Аватар для Виkтория
1 / 1 / 0
Регистрация: 04.06.2013
Сообщений: 63
11.06.2013, 23:50  [ТС]     как сделать через рекурсивную функцию ? #3
надо именно через рекурсию !! а тут оператор доступа , если не ошибаюсь ?!
Croessmah
Модератор
Эксперт CЭксперт С++
 Аватар для Croessmah
12514 / 7076 / 794
Регистрация: 27.09.2012
Сообщений: 17,477
Записей в блоге: 2
Завершенные тесты: 1
12.06.2013, 08:26     как сделать через рекурсивную функцию ? #4
Ну вот так держите:
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
#include <iostream>
using std::cout;
using std::endl;
using std::cin;
const int n=100;
 
 
void foo(int * arr,int i=0){
    std::cin>>arr[i];
    if(arr[i]!=0)
        foo(arr,i+1);
    else
        cout<<"В обратном порядке: \n";
    std::cout<<arr[i]<<std::endl;
}
 
int main(){
    int arr[n];
    setlocale (LC_ALL,"rus");
    cout << "Введите последовательность чисел:";
     foo(arr);
    system ("pause");
    return 0;
}
Добавлено через 53 секунды
Цитата Сообщение от Виkтория Посмотреть сообщение
а тут оператор доступа , если не ошибаюсь ?!
и какое отношение к рекурсии?
Yandex
Объявления
12.06.2013, 08:26     как сделать через рекурсивную функцию ?
Ответ Создать тему
Опции темы

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