Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
0 / 0 / 0
Регистрация: 12.05.2010
Сообщений: 35

Длинная арифметика (1!+2!+...+100!) в десятичной системе счисления.

16.05.2010, 14:13. Показов 2303. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ребят делаю курсовую вот и получилось,что не могу отобразить большое число (1!+2!+...+100!).
Как это можно написать через длинную арифметику?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.05.2010, 14:13
Ответы с готовыми решениями:

Длинная арифметика или как отобразить 2^500 в 10-ой системе
Ребят, как в C# можно отобразить значение 2^500 в 10ом виде?

Длинная арифметика. Перевод из десятичной системы счисления в двоичную
требуется написать программу для перевода числа с количеством цифр >20 из десятичной системы счисления в двоичную на языке С++

Записывать в двоичной системе счисления целое число, имеющее не более 100 цифр в десятичной записи
Как можно используя процедуру Randomize и функцию Random в динамическом массиве Записывать в двоичной системе счисления целое число,...

11
 Аватар для HIMen
4340 / 1509 / 101
Регистрация: 12.04.2009
Сообщений: 2,342
16.05.2010, 14:59
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
Func<int, BigInteger> factorial = null;
factorial = (n) =>
{
    BigInteger r = 1;
    for (int i = 1; i <= n; i++)
        r = r * i;
    return r;
};
BigInteger result = 0;
for (int i = 1; i <= 100; i++)
{
    result += factorial(i);
}
Console.WriteLine(result);
1
0 / 0 / 0
Регистрация: 12.05.2010
Сообщений: 35
16.05.2010, 16:53  [ТС]
Ругается компилятор
"Ошибка 1 .Не удалось найти имя типа или пространства имен "BigInteger" (пропущена директива using или ссылка на сборку?) C:\Users\*username*\AppData\Local\Tempor ary Projects\ConsoleApplication1\Program.cs"

Добавлено через 1 час 24 минуты
Ребят, ну очень надо. Помогите разобраться.
0
0 / 0 / 0
Регистрация: 17.04.2010
Сообщений: 13
16.05.2010, 16:55
.net 4 у тебя? Если нет- поставь
0
0 / 0 / 0
Регистрация: 12.05.2010
Сообщений: 35
16.05.2010, 17:04  [ТС]
а по другому написать нельзя?
0
0 / 0 / 0
Регистрация: 17.04.2010
Сообщений: 13
16.05.2010, 17:10
Можно, только придется писать большую библиотеку по работе с длинными числами.
0
0 / 0 / 0
Регистрация: 12.05.2010
Сообщений: 35
16.05.2010, 18:07  [ТС]
я наверно что-то неправильно делаю. Можно весь код программы. Вместе с классами и библиотеками, если можно
0
 Аватар для HIMen
4340 / 1509 / 101
Регистрация: 12.04.2009
Сообщений: 2,342
16.05.2010, 18:10
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
using System;
using System.Numerics;
class Program
{
    static void Main(string[] args)
    {
        Func<int, BigInteger> factorial = null;
        factorial = (n) =>
        {
            BigInteger r = 1;
            for (int i = 1; i <= n; i++)
                r = r * i;
            return r;
        };
        BigInteger result = 0;
        for (int i = 1; i <= 100; i++)
        {
            result += factorial(i);
        }
        Console.WriteLine(result);
    }
}
0
0 / 0 / 0
Регистрация: 12.05.2010
Сообщений: 35
16.05.2010, 22:08  [ТС]
Поставил .net4 проблема осталась, что делать?
0
Кодило
 Аватар для r0fL
251 / 179 / 23
Регистрация: 25.11.2009
Сообщений: 685
16.05.2010, 22:12
cofm, дотнет надо ставить не в винду, а компилятор нужен под дотнет4, то есть легче скачать вижуал студию 2010
0
 Аватар для агерон
447 / 300 / 65
Регистрация: 12.10.2009
Сообщений: 1,162
16.05.2010, 22:23
а зачем такая арифметика? новый PGP пишешь? или что то другое?
0
Эксперт JavaЭксперт С++
 Аватар для M128K145
8384 / 3617 / 419
Регистрация: 03.07.2009
Сообщений: 10,709
17.05.2010, 04:47
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/*
 * Created by SharpDevelop.
 * User: M128K145
 * Date: 04.12.2009
 * Time: 17:03
 * 
 * To change this template use Tools | Options | Coding | Edit Standard Headers.
 */
 
using System;
 
namespace Factorials
{
    /// <summary>
    /// Description of Factorial.
    /// </summary>
    public class Factorial
    {
        public Factorial()
        {
            mas = new int[n];
        }
        private const int n = 1000000;
        private int[] mas;
 
        public string PrintFactorial(int factorial)
        {
            _Factorial(factorial);
            string rezult = "";
            int i = 0, z = n - 1;
 
            while (mas[i++] == 0) ;
 
            for (i -= 1; i < n; ++i)
            {
                if ((mas[i] > 0) || (i > z))
                    z = i;
                if (mas[i] >= 100)
                    rezult += mas[i] + " ";
                else
                    if (mas[i] < 10)
                        rezult += "00" + mas[i] + " ";
                    else
                        if (mas[i] < 100)
                            rezult += "0" + mas[i] + " ";
            }
            return rezult;
        }
 
        private void _Factorial(int factorial)
        {
            int fact, i, zero = n - 1, index = n - 1;
            for (i = 0; i < n - 1; ++i)
                mas[i] = 0;
            mas[n - 1] = 1;
            for (fact = 2; fact <= factorial; ++fact)
            {
                while (mas[zero] == 0) zero--;
                for (i = zero; i >= index; --i)
                    mas[i] *= fact;
 
                for (i = zero; i > index; --i)
                    if (mas[i] >= 1000)
                    {
                        mas[i - 1] += mas[i] / 1000;
                        mas[i] %= 1000;
                    }
 
                if (mas[index] >= 1000)
                {
                    mas[index - 1] += mas[index] / 1000;
                    mas[index] %= 1000;
                    index--;
 
                    if (mas[index] >= 1000)
                    {
                        mas[index - 1] += mas[index] / 1000;
                        mas[index] %= 1000;
                        index--;
                        if (mas[index] >= 1000)
                        {
                            mas[index - 1] += mas[index] / 1000;
                            mas[index] %= 1000;
                        }
                    }
                } 
            }
        }
    }
}

Не по теме:

что за курсовые сейчас пошли?? Это же обычная лабораторная, полчаса работы

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.05.2010, 04:47
Помогаю со студенческими работами здесь

Дано целое число X в десятичной системе счисления. Выведите запись числа X в восьмеричной системе счисления
Почему настоящие программисты путают католическое Рождестово и Halloween? Потому что 25 DEC = 31 OCT. Дано целое число X в...

Длинная арифметика и системы счисления
Нужно написать программу, которая переводила бы с двоичной (вводимое число до 100 знаков) в другую систему счисления (4-19). Хотел...

Длинная арифметика: вычислить 100! - 2^100
Мне дали задание с вычеслениями длинной арифметики. С мысл в том что там все действия происходят с символьными масивами. Я так и не...

Длинная арифметика - вычислить 5^100
Могли бы вы мне подсказать принцип? Просто вообще не понимаю, как это сделать:( Вывести последовательность dk, dk–1, …, d0 десятичных...

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


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru