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

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

Войти
Регистрация
Восстановить пароль
 
trailK
1 / 1 / 0
Регистрация: 16.05.2013
Сообщений: 15
#1

Дано натуральное число n. Вычислить: S=1!+2!+3!+.+n! (n>1) - C++

04.02.2014, 15:37. Просмотров 746. Ответов 6
Метки нет (Все метки)

Дано натуральное число n. Вычислить: S=1!+2!+3!+...+n! (n>1)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
04.02.2014, 15:37
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Дано натуральное число n. Вычислить: S=1!+2!+3!+.+n! (n>1) (C++):

Дано натуральное число N и вещественное число x. Вычислить частичную сумму ряда. - C++
Дано натуральное число N и вещественное число x. Вычислить S=\sum \limits_{i = 1}^N \frac x {(N+i)!}

Дано натуральное число n, действительное число х. Вычислить sinx+sinx2+...+sinxn - C++
Прошу помочь с 3-мя задачками очень нужно сдать а сделать никак не могу. 1) Дано натуральное число n, действительное число х. Вычислить...

Дано натуральное число n и действительное число x; вычислить значение выражения - C++
Как будет по этой формуле? 1+(х^2)\2!+(x^4)\4!+...+(x^2m)\(2m)!

Дано вещественное число а и натуральное число n. Вычислить а^1,a^2,a^3,..a^n. Операцию возведения в степень не использовать - C++
Дано вещественное число а и натуральное число n. Вычислить а^1,a^2,a^3,..a^n. Операцию возведения в степень не использовать Если не...

Дано натуральное число а и целое положительное число d. Вычислить частное q и остаток r при делении а на d - C++
1 Дано натуральное число а и целое положительное число d. Вычислить частное q и остаток r при делении а на d. 2. Дано трехзначное число....

дано натуральное число N. Вычислить - C++
дано натуральное число N. Вычислить. S = \sum_{i = 1}^{n}\sum_{k = 0}^{i} \frac{i - k}{i + k}

6
ShadowFirst
55 / 48 / 1
Регистрация: 31.10.2013
Сообщений: 161
04.02.2014, 15:41 #2
C++
1
2
3
4
5
6
7
8
9
10
int retS (int n)
{
   int s = 1;
   int f = 1;
   for (int i=0;i<n;i++) {
     f*=i+1;
     s+=f;
   } 
return s;
}
0
Kuzia domovenok
1891 / 1746 / 118
Регистрация: 25.03.2012
Сообщений: 5,926
Записей в блоге: 1
04.02.2014, 16:13 #3
Факториалы быстро переполнят простой int!
0
DiffEreD
1430 / 767 / 95
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
04.02.2014, 16:14 #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
25
26
27
28
29
30
31
32
#include <iostream>
//#include <limits>
#include <vector>
#include <numeric>
#include <functional>
 
using ull = unsigned long long;
 
std::vector<ull> fuctorials(size_t value)
{
   std::vector<ull> v_fact(value);
 
   ull factor_val = 1;
   for (size_t i = 1; i <= value; ++i)
      v_fact[i-1] = (factor_val *= i);
 
   return v_fact;
}
 
int main()
{
   const size_t n = 20;
   std::vector<ull> v {fuctorials(n)};
 
   for (ull i : v) std::cout << i << "\n";
 
   //std::cout << "max of ull is:             " << std::numeric_limits<ull>::max() << "\n";
   std::cout << "Sum of factorials = "
             << std::accumulate(v.begin(), v.end(), 1ull)
             << "\n";
   return 0;
}
0
ShadowFirst
55 / 48 / 1
Регистрация: 31.10.2013
Сообщений: 161
04.02.2014, 16:15 #5
Быстро, тогда нужно использовать длинную арифметику, но принцип остается тот же))
0
кверти
4 / 4 / 1
Регистрация: 22.09.2013
Сообщений: 162
Завершенные тесты: 2
04.02.2014, 16:16 #6
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
Факториалы быстро переполнят простой int!
Они и long long быстро переполнят . Нужно использовать библиотеки для работы с бесконечно большими числами.
0
DiffEreD
1430 / 767 / 95
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
04.02.2014, 16:30 #7
Можно и подлинней сделать :
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
#include <iostream>
#include <vector>
#include <numeric>
#include <boost/multiprecision/cpp_int.hpp>
 
using vong_int = boost::multiprecision::cpp_int;
 
std::vector<vong_int> fuctorials(size_t value)
{
   std::vector<vong_int> v_fact(value);
 
   vong_int factor_val = 1;
   for (size_t i = 1; i <= value; ++i)
      v_fact[i-1] = (factor_val *= i);
 
   return v_fact;
}
 
int main()
{
   const size_t n = 58;
   std::vector<vong_int> v {fuctorials(n)};
 
   for (vong_int i : v) std::cout << i << "\n";
 
   vong_int sum = 0;
   std::cout << "\n\nSum of factorials = "
             << std::accumulate(v.begin(), v.end(), sum)
             << "\n";
   return 0;
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
04.02.2014, 16:30
Привет! Вот еще темы с ответами:

дано натуральное число N. Вычислить - C++
дано натуральное число N. Вычислить

Дано натуральное число N. Вычислить - C++
Дано натуральное число N. Вычислить: \frac{1}{2}+\frac{3}{2}+\frac{4}{3}+...+\frac{n+1}{n} Заранее спасибо.:)

Дано натуральное число n, вычислить - C++
Помогите пожалуйста решить задачи 1. Дано натуральное число n, вычислить а) \frac{1}{sin1}+\frac{1}{sin1+sin2}+...+\frac{1}{sin1+sinn} ...

Дано натуральное число n. Вычислить - C++
Пожалуйста, помогите решить задачу с помощью циклов. Дано натуральное число n. Вычислить:


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

Или воспользуйтесь поиском по форуму:
7
Yandex
Объявления
04.02.2014, 16:30
Ответ Создать тему
Опции темы

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