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

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

Войти
Регистрация
Восстановить пароль
 
QWERY_2012
5 / 5 / 2
Регистрация: 09.09.2012
Сообщений: 227
#1

сложности по рекурсии в С++ - C++

06.04.2013, 04:27. Просмотров 373. Ответов 3
Метки нет (Все метки)

Правильно ли, что в функции:
C++
1
2
3
4
5
6
7
8
9
10
11
{
 if (number < 0)
  { 
cout << '-' << endl;
super_write_vertical(abs(number));
   }
else if (number < 10)
cout << number << endl;
else { super_write_vertical(number/10);
cout << number % 10 << endl;}
 }
super_write_vertical(-1023) создаёт наибольший рекурсивный вызов из возможных:
A) super_write_vertical(-1023)

B) super_write_vertical(0)

C) super_write_vertical(100)

D) super_write_vertical(1023)???
________________________________________________________________________

Что не правильно в следующей рекурсивной функции:
C++
1
2
3
4
5
6
int recursiveSum(const int data[], int length)
{
 if (length == 1)   
return data[0];   
else 
 return data[length-1] + recursiveSum(data, length-1);
а) рекурсивная функция не может содержать массив в роли аргумента;
б) рекурсивный вызов содержит не правильный синтаксис;
в) функция не всегда обнаруживает stopping case;
г) ничего, функция правильно суммирует значения в массиве.
_____________________________________________________________

Во время компиляции программы, чем рекурсивная функция отличается от не рекурсивной:
- все параметры рассматриваются как ссылочные аргументы;
- все параметры рассматриваются как value - аргументы по значению;
- нет повторений локальных переменных;
- ничего из выше перечисленного.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
06.04.2013, 04:27     сложности по рекурсии в С++
Посмотрите здесь:

Сложности с созданим циклов C++
Сложности в написании кодов C++
Сложности с решением C++
C++ Возникли сложности
Сложности в выборе IDE C++
Сложности со структурами C++
C++ Сложности распределения памяти
Сортировка сложности O(n log(n) C++
Сложности с массивом со строками C++
C++ Сложности в изучении С++
C++ Оценка сложности алгоритма
задание повышенной сложности C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
abit
260 / 259 / 33
Регистрация: 03.02.2013
Сообщений: 709
06.04.2013, 04:44     сложности по рекурсии в С++ #2
1) A)
да, та функция расписывает построчно символы числа, в "-1023" больше всего символов (т.к. есть "-")

2) В)
нормальная функция, аргументы верны, массив не меняется, передаётся указатель на него, уверен что сумму элементов выдаст, однако если массив пуст - ничего хорошего не будет... у неё stop case только для длины массива >=1
и кстати вместо
int length

следует задать
size_t length


3) -ничего из выше перечисленного
хотя тут меньше уверен, удивлюсь если другой ответ
Croessmah
Модератор
Эксперт CЭксперт С++
12878 / 7264 / 810
Регистрация: 27.09.2012
Сообщений: 17,945
Записей в блоге: 2
Завершенные тесты: 1
06.04.2013, 08:31     сложности по рекурсии в С++ #3
Цитата Сообщение от QWERY_2012 Посмотреть сообщение
Что не правильно в следующей рекурсивной функции:
3) Имхо, вириант В. Если length будет сразу меньше единицы, тогда беда...
MrGluck
Ворчун
Эксперт CЭксперт С++
6625 / 3816 / 500
Регистрация: 29.11.2010
Сообщений: 10,072
06.04.2013, 09:00     сложности по рекурсии в С++ #4
прям как в ЕГЭ, с одной стороны ф-ция таки суммирует, с другой, контроля на переданные данные нет, так что возможно и вариант В. Ответ в голове того, кто этот вопрос создал.
Yandex
Объявления
06.04.2013, 09:00     сложности по рекурсии в С++
Ответ Создать тему
Опции темы

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