Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 5.00/64: Рейтинг темы: голосов - 64, средняя оценка - 5.00
1 / 1 / 0
Регистрация: 26.05.2020
Сообщений: 47

Последняя цифра факториала

14.06.2020, 18:55. Показов 12454. Ответов 34
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Для заданного натурального N найти последнюю ненулевую цифру числа
могу найти факториал но не цифру
Python
1
2
3
4
5
6
7
8
9
def factorial(n):
    k = 0
    p = 1
    for i in range(n):
        k += 1
        p = p*k
    return p
n = int(input())
print(factorial(n))
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.06.2020, 18:55
Ответы с готовыми решениями:

Последняя цифра числа Фибоначчи
Помогите найти в этом коде ошибку, Условие: Последовательность чисел Фибоначчи определяется следующим образом: F0 = F1 = 1, Fn+1...

Последняя цифра суммы чисел равна определенной цифре
Нужно написать такой код в Python, чтобы, к примеру: 156462-1545-35872-154465452-45646 Вывести числа, последняя цифра суммы которых...

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

34
1 / 1 / 0
Регистрация: 26.05.2020
Сообщений: 47
14.06.2020, 23:15  [ТС]
Студворк — интернет-сервис помощи студентам
это я понял оно работает но на проверке пишут что долго
0
291 / 193 / 104
Регистрация: 14.11.2017
Сообщений: 489
14.06.2020, 23:17
massa431, а вам точно нужно искать и факториал, и сразу его последнюю цифру?
0
1 / 1 / 0
Регистрация: 26.05.2020
Сообщений: 47
14.06.2020, 23:19  [ТС]
он работает, но на проверке пишут что долго

Добавлено через 1 минуту
нужно искать только последнюю цифру
например ввод 5
вывод 2
0
291 / 193 / 104
Регистрация: 14.11.2017
Сообщений: 489
14.06.2020, 23:28
massa431, покажите что вы отравляете на проверку
0
1 / 1 / 0
Регистрация: 26.05.2020
Сообщений: 47
14.06.2020, 23:33  [ТС]
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
def factorial(n):
    k = 0
    p = 1
    for i in range(n):
        k += 1
        p = p*k
    return p
n = int(input())
g = factorial(n)
 
rem = g % 10
while rem == 0:
    g //= 10
    rem = g % 10
print(rem)
0
291 / 193 / 104
Регистрация: 14.11.2017
Сообщений: 489
14.06.2020, 23:42
Попробуйте такую функцию факториала
Python
1
2
3
4
5
6
7
8
9
def f(l, r):
    if l > r:
        return 1
    if l == r:
        return l
    if r - l == 1:
        return l * r
    m = (l + r) / 2
    return f(l, m) * f(m + 1, r)
Добавлено через 14 секунд
Вызывать вот так:
Python
1
f(2, n)
0
Фрилансер
 Аватар для Black Fregat
3709 / 2083 / 567
Регистрация: 31.05.2009
Сообщений: 6,683
14.06.2020, 23:44
Лучший ответ Сообщение было отмечено palva как решение

Решение

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
def lastDigit(n):
    res, two = 1, 0
    for i in range(2, n+1):
        while i % 10 == 0:
            i //= 10
        while i % 2 == 0:
            i //= 2
            two += 1
        while i % 5 == 0:
            i //= 5
            two -= 1
        res = res * i % 10
    res *= [6, 2, 4, 8][two % 4]
    return res % 10
1
1 / 1 / 0
Регистрация: 26.05.2020
Сообщений: 47
14.06.2020, 23:52  [ТС]
а как его получить?

Добавлено через 6 минут
а что это?
0
Фрилансер
 Аватар для Black Fregat
3709 / 2083 / 567
Регистрация: 31.05.2009
Сообщений: 6,683
15.06.2020, 00:33
Цитата Сообщение от massa431 Посмотреть сообщение
а что это?
Это функция. На Питоне. Вы не знаете, как вызвать функцию?
0
15.06.2020, 14:20

Не по теме:

massa431, не понимаю людей, которые демонстративно нарушают правила.
Факториал
Как вы собираетесь жить за чужой счет в этой жизни -- это не моё дело, но свою помощь в той ветке я убрал.

0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
15.06.2020, 14:51
Python
1
2
3
4
>>> from math import factorial
>>> factorial(4)
24
>>>
Цитата Сообщение от massa431 Посмотреть сообщение
но на проверке пишут что долго
Используй другие алгоритмы. Наивный алгоритм
Python
1
2
3
4
5
def fact(n): 
    f = 1
    for i in range(1,n + 1):
        f *= i
    return f
работает ... наивно.

https://habr.com/ru/post/255761/#comment_8379739
0
5516 / 2869 / 571
Регистрация: 07.11.2019
Сообщений: 4,759
16.06.2020, 08:26
Задачка интересная..
Мне кажется, что все множители факториала можно разбить на классы, в зависимости от того, на что оканчивается множитель. Например: Число 13, множители факториала 2,3,4,5,6,7,8,9,10,11,12,13, классы: 2,3,4,5,6,7,8,9,1,1,2,3.
или можно переписать, с учетом кратности: 1**2, 2**2, 3**2, 4**1, 5**1,6**1,7**1,8**1,9**1. Степени будут образовывать циклические группы ( 5 - случай особый), для тройки, циклическая группа 4-го порядка: 3-9-(2)7-(8)1-(24)3.
Таким образом, думаю, что возможно вычисление быстрое последней цифры факториала без вычисления самого факториала.
Вот такая идея, прошу ее оценить/покритиковать.
0
Фрилансер
 Аватар для Black Fregat
3709 / 2083 / 567
Регистрация: 31.05.2009
Сообщений: 6,683
16.06.2020, 09:03
Цитата Сообщение от u235 Посмотреть сообщение
думаю, что возможно вычисление быстрое последней цифры факториала без вычисления самого факториала.
А чего думать, я выше готовый код привёл
0
1 / 0 / 0
Регистрация: 24.06.2021
Сообщений: 1
15.09.2021, 09:33
Python
1
2
3
4
5
6
7
8
9
10
dig = [1, 1, 2, 6, 4, 2, 2, 4, 2, 8]
def lastNon0Digit(n):
  if (n < 10):
    return dig[n];
  if (((n//10)%10)%2 == 0):
    return (6*lastNon0Digit(n//5)*dig[n%10]) % 10
  else:
    return (4*lastNon0Digit(n//5)*dig[n%10]) % 10
n=int(input())
print(lastNon0Digit(n))
Работает быстро, если надо, скину с комментариями
0
7 / 7 / 0
Регистрация: 27.02.2022
Сообщений: 35
20.06.2022, 11:00
Я считаю что это не тот подход к задаче (это задача мне встретилась в Сириусе) и понятно что там считать факториал это самоубийство особенно когда число может быть 1000000! там проделываются несколько другие махинации
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.06.2022, 11:00
Помогаю со студенческими работами здесь

Создать список из 17 целых чисел. Сначала найдите сумму всех элементов списка, у которых последняя цифра 7
Создать список из 17 целых чисел. Сначала найдите сумму всех элементов списка, у которых последняя цифра 7. Затем (новый список не...

Все числа, последняя цифра которых делится на 3
Напишите программу, которая от A до B выводит все числа, последняя цифра которых делится на 3

Сколько раз в числе повторяется последняя цифра
Доброго времени суток, не могли бы помочь с решением задачи: дано n-значное число , определить сколько раз в этом числе повторяется...

Найдите первое число в массиве,у которого последняя цифра - 2
Заполните массив из 10 элементов случайными числами в диапазоне (100,200). Найдите первое число в массиве,у которого последняя цифра - 2

Выясните какая цифра числа больше первая или последняя
Задайте случайное трехзначное число выясните какая цифра больше первая или последняя или они равны если первая больше последней число...


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

Или воспользуйтесь поиском по форуму:
35
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru