Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 23.10.2013
Сообщений: 33

Рекурсивная функция для вычисления арифметической функции

06.09.2014, 19:34. Показов 1903. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго время суток. Требуется построить рекурсивную функцию, реализующую вычисление арифметической функции:X1 * X2.
С одноместными функциями всё понятно, но с двухместной вообще неразбериха. Даже не представляю с чего начать. Подскажите, пожалуйста.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.09.2014, 19:34
Ответы с готовыми решениями:

Рекурсивная функция для вычисления суммы элементов арифметической прогрессии
#include <stdio.h> #include <conio.h> int pr(int n, int a1, int d,int sum) { if(n==1) return a1; sum=a1+(n-1)*d+pr(n-1,a1,d); ...

Рекурсивная функция для вычисления последовательности
Может кто-то знает как это делать и может помочь. Честно говоря я в рекурсии не силён. Задание звучит примерно так: Описать рекурсивную...

Рекурсивная функция для вычисления суммы ряда
помогите вычислить сумму с использованием рекурсивной функции. Программу написал, но сумму она не считает, а просто выдает все члены...

7
1406 / 648 / 135
Регистрация: 11.08.2011
Сообщений: 2,299
Записей в блоге: 2
06.09.2014, 19:50
Лучший ответ Сообщение было отмечено Georguy как решение

Решение

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <iostream>
 
 
unsigned multiply(unsigned x1, unsigned x2)
{
    if(x1==0)
        return 0;
    return multiply(x1-1, x2) + x2;
}
 
 
int main()
{
    std::cout << multiply(5, 6) << std::endl;
    return 0;
}
1
0 / 0 / 0
Регистрация: 23.10.2013
Сообщений: 33
06.09.2014, 20:01  [ТС]
Ох, спасибо за код огромное. Можете немного добавить комментариев, а то не особо понятно к чему "+" в возвращении функции. Ну и что бы раз и навсегда разобраться?
0
:)
Эксперт С++
4773 / 3267 / 497
Регистрация: 19.02.2013
Сообщений: 9,046
06.09.2014, 20:53
Лучший ответ Сообщение было отмечено Georguy как решение

Решение

Цитата Сообщение от Georguy Посмотреть сообщение
а то не особо понятно к чему "+" в возвращении функции.
Умножение через сложение представить не можете?
1
4949 / 2289 / 287
Регистрация: 01.03.2013
Сообщений: 5,991
Записей в блоге: 32
06.09.2014, 20:57
Лучший ответ Сообщение было отмечено Georguy как решение

Решение

Цитата Сообщение от Georguy Посмотреть сообщение
С одноместными функциями всё понятно, но с двухместной вообще неразбериха. Даже не представляю с чего начать. Подскажите, пожалуйста.
Если ситуация с вашим пониманием действительно такова, как вы ее описали, тогда сделайте с "одножоместной" функцией. Cделайте x2 глобальной переменной, ее не надо будет передавать в качестве параметра в рекурсивную функцию, напишите код (раз вам все понятно). Покажите ваш код сюда.
1
0 / 0 / 0
Регистрация: 23.10.2013
Сообщений: 33
07.09.2014, 11:08  [ТС]
Ну как-то так

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream>
 
using namespace std;
 
short x2 = 6;
 
int recursion(short x1){
    if (x1 == 0)
        return 0;
    return recursion(x1 - 1) + x2;
}
 
int main(){
    int y = recursion(5);
        cout << y << endl;
    system("pause");
    return 0;
}
0
4949 / 2289 / 287
Регистрация: 01.03.2013
Сообщений: 5,991
Записей в блоге: 32
07.09.2014, 14:48
Georguy, хорошо, а я уже думал что вы лукавили, когда утверждали что вам все понятно с "одноместной" функцией. Правда ваш код как две капли воды похож на код Dani, с точностью до форматирования, и судя по предыдущим постам вы испытывали трудности в представлении умножения через сложение, но допустим вы действительно сами написали и понимаете ваш код. А теперь внимание, вопрос - чем он отличается принципиально от кода Dani? Есть второй параметр у функции, он передается по значению (надеюсь, вы в курсе что это такое), при этом в теле самой функции он никак не изменяется, и при следующем рекурсивном вызове его значение транзитом катится вглубь рекурсии, бесполезно пожирая стек, но мы на это закрываем глаза. И в данном случае с точки зрения результата все равно, как мы во вложенных уровнях вызова получаем наше х2 - через глобальную переменную, или переданную параметром по значению или параметром по ссылке.
0
0 / 0 / 0
Регистрация: 23.10.2013
Сообщений: 33
07.09.2014, 15:30  [ТС]
Цитата Сообщение от _Ivana Посмотреть сообщение
Georguy, хорошо, а я уже думал что вы лукавили, когда утверждали что вам все понятно с "одноместной" функцией. Правда ваш код как две капли воды похож на код Dani, с точностью до форматирования, и судя по предыдущим постам вы испытывали трудности в представлении умножения через сложение, но допустим вы действительно сами написали и понимаете ваш код. А теперь внимание, вопрос - чем он отличается принципиально от кода Dani? Есть второй параметр у функции, он передается по значению (надеюсь, вы в курсе что это такое), при этом в теле самой функции он никак не изменяется, и при следующем рекурсивном вызове его значение транзитом катится вглубь рекурсии, бесполезно пожирая стек, но мы на это закрываем глаза. И в данном случае с точки зрения результата все равно, как мы во вложенных уровнях вызова получаем наше х2 - через глобальную переменную, или переданную параметром по значению или параметром по ссылке.
На данном этапе изучения я еще не знакомился со стеком, так что не обессудьте.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.09.2014, 15:30
Помогаю со студенческими работами здесь

Рекурсивная функция для вычисления по заданной формуле
Напишите функцию, вычисляющую xn без использования цикла, где n – некоторое натуральное число, вводимое в качестве аргумента функции, а...

Рекурсивная функция для вычисления суммы ряда
#include &lt;iostream&gt; #include&lt;cmath&gt; int sum(int a); int main() { int n; std::cout &lt;&lt; &quot;Enter the number: &quot;; std::cin &gt;&gt; n; ...

Рекурсивная функция для вычисления члена последовательности
С клавиатуры вводится номер члена последовательности, который нужно вычислить. Последовательность такая: 1,1,1/4,16/25. Закономерность...

Рекурсивная функция нахождения суммы арифметической прогрессии
Помогите. Не понимаю как написать. Даны первый член и разницу арифметической прогрессии. Написать рекурсивной функцию для...

Рекурсивная функция для вычисления цепочки дробей с факториалом
Здравствуйте, надо написать прогу для решения вот этого примера. #include &lt;iostream&gt; #include &lt;cstdio&gt; #include...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru