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

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

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

Дано натуральное число n. Вычислить C++
Дано натуральное число.... Вычислить C++
C++ Дано натуральное число N. вычислить
Дано вещественное число а и натуральное число n. Вычислить а^1,a^2,a^3,..a^n. Операцию возведения в степень не использовать C++
C++ Дано натуральное число N и вещественное число x. Вычислить частичную сумму ряда.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ShadowFirst
54 / 47 / 1
Регистрация: 31.10.2013
Сообщений: 161
04.02.2014, 15:41     Дано натуральное число n. Вычислить: S=1!+2!+3!+.+n! (n>1) #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;
}
Kuzia domovenok
 Аватар для Kuzia domovenok
1883 / 1738 / 116
Регистрация: 25.03.2012
Сообщений: 5,907
Записей в блоге: 1
04.02.2014, 16:13     Дано натуральное число n. Вычислить: S=1!+2!+3!+.+n! (n>1) #3
Факториалы быстро переполнят простой int!
DiffEreD
 Аватар для DiffEreD
1420 / 757 / 95
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
04.02.2014, 16:14     Дано натуральное число n. Вычислить: S=1!+2!+3!+.+n! (n>1) #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;
}
ShadowFirst
54 / 47 / 1
Регистрация: 31.10.2013
Сообщений: 161
04.02.2014, 16:15     Дано натуральное число n. Вычислить: S=1!+2!+3!+.+n! (n>1) #5
Быстро, тогда нужно использовать длинную арифметику, но принцип остается тот же))
кверти
4 / 4 / 1
Регистрация: 22.09.2013
Сообщений: 133
Завершенные тесты: 2
04.02.2014, 16:16     Дано натуральное число n. Вычислить: S=1!+2!+3!+.+n! (n>1) #6
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
Факториалы быстро переполнят простой int!
Они и long long быстро переполнят . Нужно использовать библиотеки для работы с бесконечно большими числами.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
04.02.2014, 16:30     Дано натуральное число n. Вычислить: S=1!+2!+3!+.+n! (n>1)
Еще ссылки по теме:

Дано натуральное число n. Вычислить S=1/3^2+1/5^2+1/7^2+...+1/(2*n+1)^2 C++
C++ Дано натуральное число n, действительное число х. Вычислить sinx+sinx2+...+sinxn
C++ Дано натуральное число N. Вычислить

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

Или воспользуйтесь поиском по форуму:
DiffEreD
 Аватар для DiffEreD
1420 / 757 / 95
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
04.02.2014, 16:30     Дано натуральное число n. Вычислить: S=1!+2!+3!+.+n! (n>1) #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;
}
Yandex
Объявления
04.02.2014, 16:30     Дано натуральное число n. Вычислить: S=1!+2!+3!+.+n! (n>1)
Ответ Создать тему
Опции темы

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