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

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

14.06.2020, 18:55. Показов 12520. Ответов 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
5439 / 3860 / 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
5526 / 2879 / 572
Регистрация: 07.11.2019
Сообщений: 4,774
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
Ответ Создать тему
Новые блоги и статьи
[golang] Конкурентный fetcher с ограничением максимального количества одновременных HTTP запросов.
alhaos 10.06.2026
Задача Реализовать конкурентный fetcher с ограничением максимального количества одновременных HTTP запросов. Сигнатура func Fetch(urls string, maxConcurrent int) Result Пример urls :=. . .
[golang] Состояние гонки (race condition)
alhaos 10.06.2026
Состояние гонки (race condition) Состояние гонки (Race Condition) — это ошибка, возникающая при одновременном доступе нескольких горутин к одним и тем же данным без должной синхронизации. При этом. . .
Взрослые отношения, и почему они не получаются
kumehtar 09.06.2026
Когда в детстве ребёнок не получает от родителей чего-то важного, он лишается не просто приятных переживаний, а основы для формирования определённых внутренних качеств и навыков. Если ребёнок не. . .
[golang] Worker Pool
alhaos 09.06.2026
Worker Pool Worker Pool — паттерн конкурентной обработки задач в Go. Суть: фиксированное количество горутин-воркеров читают задачи из общего канала и пишут результаты в общий канал результатов. . . .
[golang] Pipeline
alhaos 08.06.2026
Pipeline Pipeline — паттерн конкурентной обработки данных в Go. Суть: данные проходят через цепочку независимых стадий, каждая из которых работает в своей горутине и общается с соседями через. . .
Свет внутри себя
kumehtar 07.06.2026
Пусть это будет здесь lIs4oanZS9Y
Программа для com-порта
Uhbif79 05.06.2026
Всем привет, давно хотел изучить Qt, начинал, бросал, потом снова начинал. И сейчас вот смог написать свою первую программу. До этого имел опыт программирования микроконтроллеров, писал прошивки на. . .
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru