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

Рекурсивно найти сумму факториалов всех натуральных чисел до n

15.05.2018, 17:28. Показов 3481. Ответов 6
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Нужно найти сумму факториалов всех натуральных числе до n (n вводит пользователь). Проблема заключается в том, что задачу нужно реализовать в виде рекурсивной функции.

Рекурсивных функций факториала полно. Вот, например, одна из них:

C++
1
2
3
4
5
6
int f(int n)
{
    if (n == 1)
        return 1;
    return f(n-1)*n;
}
Но как ее можно переделать под мое задание? Не могу никак сообразить, помогите, пожалуйста разобраться!
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.05.2018, 17:28
Ответы с готовыми решениями:

Найдите сумму факториалов всех натуральных чисел до данного N
Помогите пожалуйста с программкой. По возможности необходимо использовать printf и scanf. Найдите...

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

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

Вычислить сумму факториалов всех нечетных чисел от 1 до 9
C++ for dos v.3.1. вычислить сумму факториалов всех нечетных чисел от 1 до 9 вот что у меня...

6
Форумчанин
Эксперт CЭксперт С++
8216 / 5046 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
15.05.2018, 17:50 2
К вашей функции добавить ещё одну рекурсивную
C++
1
2
3
4
int g(int n)
{
    return n ? f(n) + g(n-1) : 0;
}
0
139 / 109 / 60
Регистрация: 26.10.2013
Сообщений: 314
15.05.2018, 17:52 3
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
using int_t = long long;
 
int_t fact(int n)
{
    if (n == 1 || n == 0)
        return 1;
 
    return fact(n - 1) * n;
}
 
int_t sum_fact(int n)
{
    return n > 0 ? fact(n) + sum_fact(n - 1) : 0;
}
0
-44 / 2 / 3
Регистрация: 22.12.2015
Сообщений: 508
15.05.2018, 17:58  [ТС] 4
Вот она и проблема в том, что по отдельности написать функции не проблема. А в задании хотят, чтобы я сделал это все в одной. Это вообще реально?
0
Форумчанин
Эксперт CЭксперт С++
8216 / 5046 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
15.05.2018, 18:24 5
Цитата Сообщение от Imperion Посмотреть сообщение
А в задании хотят, чтобы я сделал это все в одной
В нём прямо сказано, что всё должно быть в одной рекурсивной функции?
0
-44 / 2 / 3
Регистрация: 22.12.2015
Сообщений: 508
15.05.2018, 20:26  [ТС] 6
Да, сказано следующее: разработайте функцию или процедуру для решения следующего задания и само задание
0
693 / 303 / 99
Регистрация: 04.07.2014
Сообщений: 846
16.05.2018, 10:18 7
Лучший ответ Сообщение было отмечено Imperion как решение

Решение

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
namespace {
struct sf_t {
  unsigned fact;
  unsigned sum;
};
 
sf_t sum_factorials_(unsigned n)
{
  sf_t t;
 
  switch (n) {
  case 0u:
    t.fact = 0u;
    t.sum = 0u;
    break;
  case 1u:
    t.fact = 1u;
    t.sum = 1u;
    break;
  default:
    t = sum_factorials_(n - 1u);
    t.fact *= n;
    t.sum += t.fact;
  }
  return t;
}
}
 
unsigned sum_factorials(unsigned n)
{
  return sum_factorials_(n).sum;
}
1
16.05.2018, 10:18
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.05.2018, 10:18
Помогаю со студенческими работами здесь

Нерекурсивные процедуры и функции: вычислить сумму факториалов всех нечетных чисел от 1 до 9
Написать программу для вычисления суммы факториалов всех нечетных чисел от 1 до 9 Добавлено...

Как найти сумму факториалов двух чисел?
Помогите решить задачу: найти суму факториалов двух чисел n!+m!, если n=4,m=6. #include <stdio.h>...

Найдите сумму, количество и среднее арифметическое всех натуральных двухзначных чисел
Найдите сумму, количество и среднее арифметическое всех натуральных двухзначное цифр, состоящих...

В последовательности всех натуральных чисел от 1 до k найти k-ую цифру
Разработать программу, которая запрашивает с клавиатуры натуральное число k и определяет k-ую цифру...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Как написать микросервис на Go/Golang
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C#
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
Как создать игру "Танчики" на Unity3d и C#
InfoMaster 14.01.2025
Разработка игр – это увлекательный процесс, сочетающий в себе творчество и технические навыки. В этой статье мы рассмотрим создание классической игры "Танчики" с использованием Unity3D и языка. . .
Организую платный онлайн микро-курс по доработке Android-клиента Telegram
_Ivana 14.01.2025
Официальная версия и распространенные форки не полностью устраивают? Сделай свою кастомную версию клиента! 4 занятия по 2 часа (2 недели пн, ср 19:00-21:00 по Москве). Первое вводное занятие. . .
Как создать приложение для фитнеса для iOS/iPhone на Kotlin
InfoMaster 14.01.2025
Создание собственного фитнес-приложения — это не только захватывающий, но и полезный процесс, ведь оно может стать вашим верным помощником на пути к здоровому и активному образу жизни. В современных. . .
Как создать приложение магазина для iOS/iPhone на Swift
InfoMaster 14.01.2025
Введение в разработку iOS-приложений Разработка приложений для iPhone и других устройств на базе iOS открывает огромные возможности для создания инновационных мобильных решений. В данной статье мы. . .
Это работает. Скорость асинхронной логики велика. Вопрос видимо останется в стабильности. Плата - огонь!
Hrethgir 13.01.2025
По прошлому проекту в Logisim Evolution https:/ / www. cyberforum. ru/ blogs/ 223907/ blog8781. html прилагаю файл архива проекта в Gowin Eda. Восьмибитный счётчик из сумматора+ генератор сигнала. . .
UserScript для подсветки кнопок языков программировани­­­­я в зависимости от текущего раздела
volvo 13.01.2025
В результате работы этого скрипта подсвечиваются нужные кнопки не только в форме быстрого ответа, но и при редактировании сообщения: / / ==UserScript== / / @name CF_DefaultLangSelect / / . . .
Введение в модели и алгоритмы машинного обучения
InfoMaster 12.01.2025
Машинное обучение представляет собой одну из наиболее динамично развивающихся областей искусственного интеллекта, которая фокусируется на разработке алгоритмов и методов, позволяющих компьютерам. . .
Как на Python создать нейросеть для решения задач
InfoMaster 12.01.2025
В контексте стремительного развития современных технологий особое внимание уделяется таким инструментам, как нейросети. Эти структуры, вдохновленные биологическими нейронными сетями, используются для. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru