Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
3 / 3 / 2
Регистрация: 18.05.2014
Сообщений: 203

Задача на арифметику остатков

30.09.2015, 22:43. Показов 844. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, есть задача :

Срочно нужно посчитать факториал чила. Срочно! Сейчас же!!! Ну ладно хотя бы по модулю 10^9 + 7. Но срочно!

Входные данные
В единственной строке дано число N (0 ≤ N ≤ 10^8) — факториал которого нужно вычислить.

Выходные данные
Выведите результат вычисления факториала по модулю.

Код

C++
1
2
3
4
5
 while(i <= N)
    {
        res = ( (res % c)*(i % c) ) % c;
        i++;
    }
Не проходит по времени, что можете посоветовать, спасибо
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
30.09.2015, 22:43
Ответы с готовыми решениями:

Задача на длинную арифметику
Доброе время суток. Помогите, пожалуйста, дана задача определить общую сумму от карандашей, фломастеров и ручек (Количество каждых не...

Задача на адресную арифметику
Добрий день. Допоможіть, будь ласка, вирішити такі завдання: Написати програму на мові Сі, яка складається з наступних дій: 1. Створення за...

Задача на длинную арифметику
Всем привет! Есть такая задача {deleted} на использовании длинной арифметики. Не получается её решить, кто-нибудь может помочь,...

4
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
01.10.2015, 00:52
По табличке. Хрен его знает пройдет ли по лимитам времени, но точно будет быстрее чем у вас.
C++
1
2
3
4
5
6
7
8
9
const int div=10000;
int table[]={готовая таблица факториалов от N*div. Факториал нуля считается за единицу};
int fact(int n)
{
    int64_t res=table[n/div];
    for(int i=(n/div)*div+1;i<=n;++i)
        res=(res*i)%1000000007;
    return res;
}
1
 Аватар для Barrent
252 / 128 / 54
Регистрация: 04.05.2013
Сообщений: 346
01.10.2015, 01:39
Формула Стрилинга?
Во многих случаях для приближённого значения факториала достаточно рассматривать только главный член формулы Стирлинга:
Изображения
 
0
3 / 3 / 2
Регистрация: 18.05.2014
Сообщений: 203
01.10.2015, 01:48  [ТС]
Renji, поясните, пожалуйста как она работает и как я смогу запихнуть в тип int факториалы чисел от 0 до 9999, например n = 20100, тогда res = 2, i = 20001, а перебор происходит от 20001 до 20100, то есть res будет
(2 * 20001) % и т.д., но это уже совсем неясно, почему мы 2* 20001? спасибо
0
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
01.10.2015, 01:59
Цитата Сообщение от maksvolf96 Посмотреть сообщение
Renji, поясните, пожалуйста как она работает и как я смогу запихнуть в тип int факториалы чисел от 0 до 9999
Поправка - "таблица факториалов от N*div % 1000000007".
Цитата Сообщение от maksvolf96 Посмотреть сообщение
например n = 20100, тогда res = 2, i = 20001
Тогда res=(факториал 2*10000)%1000000007. В табличке факториалы идут с шагом 10000.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.10.2015, 01:59
Помогаю со студенческими работами здесь

Задача на длинную арифметику
нужно вычислить 100! + 2^100 (2 в степени 100) и в результате сохранить все цифры.

Задача на арифметику
В заданном одномерном массиве поменять местами соседние элементы , состоящие на четных местах, с элементами, стоящими на нечетных местах

Задача на длинную арифметику
Итак, входные данные: число S&lt;=60000. Это s-тое число фибонначи (если 2 то 2, если 4 то 5, если 5 то 8). Нужно с помощью процедуры(или...

Задача на длинную арифметику
Нужно вычислить 100! - 2^100, используя длинную арифметику...Подскажите, кто чем может, пожалуйста.

Задача на длинную арифметику: прибавить к ОДЦ единицу
Для ОченьДлинногоЦелого числа решить задание по варианту. Решение оформить в виде функции. ОченьДлинноеЦелое – неотрицательное число...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru