С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
2 / 2 / 2
Регистрация: 14.12.2013
Сообщений: 120
1

Просуммировать члены последовательности с использованием рекурсивного вызова

22.03.2014, 08:45. Показов 1315. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте! Мною была составлена программа, содержащая подпрограмму с рекурсивным вызовом, и находящая решение уравнения 1*2+2*3*4+3*4*5*6+n*(n-1)*...*2n. Выглядит она следующим образом:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <stdio.h>
#include <math.h>
#include <conio.h>
int func (int n)
{int i;  int F; int k; int j;
for (i=1;i<=n;++i)
{
    k=1;
    for (j=i;j<=2*i;++j) k*=j;
    F+=k;
}
}
int main()
{int n; int F;
printf ("Vvedite n=");
scanf("%d", &n);
F=func(n);
printf("znacnenie F=%d", F);
getch();
}
Вся проблема в том, что на выходе получается F=0, хотя F должна иметь совсем другое значение (в зависимости от переменной n). Не могу найти ошибку.
Надеюсь на вашу помощь
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
22.03.2014, 08:45
Ответы с готовыми решениями:

Расчет факториала (с использованием рекурсивного вызова подпрограммы)
Доброго времени суток! У меня вопрос как реализовать программу следующего типа: Расчет факториала...

сформировать путем рекурсивного вызова аналитическое выражение
С помощью модуля первой формы ввести с клавиатуры показатель степени n и сформировать путем...

Как должны изменяться аргументы рекурсивного вызова?
Собственно такой вопрос. Как должны изменяться аргументы рекурсивного вызова? Мне кажется,...

Каким образом в переменную записывается результат каждого рекурсивного вызова?
Всем привет! Подскажите по данной задачи, немного недопонимаю: ФАКТОРИАЛ: int FACT(int n) {int...

3
Модератор
Эксперт С++
13720 / 10917 / 6478
Регистрация: 18.12.2011
Сообщений: 29,146
22.03.2014, 10:14 2
Лучший ответ Сообщение было отмечено zaqwerty как решение

Решение

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
int func (int n)
{
    int i, F, k, j;
    F=0;
    for (i=1;i<=n;++i)
    {
       k=1;
       for (j=i;j<=2*i;++j)
                 k*=j;
        F+=k;
   }
   return F;
}
p.s. Такие выражения называются не уравнениями, а последовательностями.
И Вы суммируете члены последовательности:
a1+a2+...+an
1
135 / 134 / 53
Регистрация: 13.09.2013
Сообщений: 260
Записей в блоге: 2
22.03.2014, 10:25 3
Цитата Сообщение от zaqwerty Посмотреть сообщение
int func (int n)
Возвращать то нужно что то, вот сюда:
Цитата Сообщение от zaqwerty Посмотреть сообщение
F=func(n);
1
2 / 2 / 2
Регистрация: 14.12.2013
Сообщений: 120
22.03.2014, 10:32  [ТС] 4
zss, спасибо большое, программа заработала
Цитата Сообщение от zss Посмотреть сообщение
Такие выражения называются не уравнениями, а последовательностями
В дальнейшем учту)
0
22.03.2014, 10:32
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
22.03.2014, 10:32
Помогаю со студенческими работами здесь

Переставить члены последовательности так, чтобы сначала расположились все ее неотрицательные члены
Помогите пожалуйста решить задачу!!! Экзамен горит.... Выручайте!!! Дана очередь, элементами...

Переставить члены последовательности так, чтобы сначала расположились все ее неотрицательные члены
Помогите решить задачу! :cofee2: Дана очередь, элементами которой являются действительные числа....

Update с использованием рекурсивного запроса
Есть иерархическая таблица, поле с иерархией parent_id, нужно заполнить level - уровень...

ЗАПРОС С ИСПОЛЬЗОВАНИЕМ РЕКУРСИВНОГО СОЕДИНЕНИЯ
как вы думаете можно создать рекурсивный запрос для таблицы, в которой лежат имена, фамилии, номера...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru